tlc-claude-code 1.6.2 → 1.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/commands/tlc/audit.md +0 -0
- package/.claude/commands/tlc/autofix.md +0 -0
- package/.claude/commands/tlc/bug.md +0 -0
- package/.claude/commands/tlc/build.md +6 -0
- package/.claude/commands/tlc/checklist.md +0 -0
- package/.claude/commands/tlc/ci.md +0 -0
- package/.claude/commands/tlc/claim.md +0 -0
- package/.claude/commands/tlc/cleanup.md +0 -0
- package/.claude/commands/tlc/complete.md +0 -0
- package/.claude/commands/tlc/config.md +0 -0
- package/.claude/commands/tlc/coverage.md +0 -0
- package/.claude/commands/tlc/deploy.md +0 -0
- package/.claude/commands/tlc/discuss.md +0 -0
- package/.claude/commands/tlc/docs.md +0 -0
- package/.claude/commands/tlc/edge-cases.md +0 -0
- package/.claude/commands/tlc/export.md +0 -0
- package/.claude/commands/tlc/help.md +0 -0
- package/.claude/commands/tlc/import-project.md +0 -0
- package/.claude/commands/tlc/init.md +35 -37
- package/.claude/commands/tlc/issues.md +0 -0
- package/.claude/commands/tlc/llm.md +0 -0
- package/.claude/commands/tlc/new-milestone.md +0 -0
- package/.claude/commands/tlc/new-project.md +0 -0
- package/.claude/commands/tlc/next.md +0 -0
- package/.claude/commands/tlc/outdated.md +0 -0
- package/.claude/commands/tlc/plan.md +0 -0
- package/.claude/commands/tlc/progress.md +0 -0
- package/.claude/commands/tlc/quality.md +0 -0
- package/.claude/commands/tlc/quick.md +0 -0
- package/.claude/commands/tlc/refactor.md +0 -0
- package/.claude/commands/tlc/release.md +0 -0
- package/.claude/commands/tlc/review-pr.md +0 -0
- package/.claude/commands/tlc/review.md +0 -0
- package/.claude/commands/tlc/security.md +0 -0
- package/.claude/commands/tlc/server.md +0 -0
- package/.claude/commands/tlc/start.md +0 -0
- package/.claude/commands/tlc/status.md +0 -0
- package/.claude/commands/tlc/sync.md +0 -0
- package/.claude/commands/tlc/tlc.md +38 -31
- package/.claude/commands/tlc/verify.md +0 -0
- package/.claude/commands/tlc/who.md +0 -0
- package/.gitattributes +0 -0
- package/CLAUDE.md +113 -61
- package/CODING-STANDARDS.md +0 -0
- package/LICENSE +0 -0
- package/PROJECT.md +0 -0
- package/README.md +0 -0
- package/autofix.md +0 -0
- package/bin/init.js +0 -0
- package/bin/install.js +0 -0
- package/bin/postinstall.js +0 -0
- package/bin/rebuild.js +0 -0
- package/bin/server.js +0 -0
- package/bin/setup.js +0 -0
- package/bin/tlc.js +0 -0
- package/bug.md +0 -0
- package/build.md +0 -0
- package/checklist.md +0 -0
- package/ci.md +0 -0
- package/claim.md +0 -0
- package/complete.md +0 -0
- package/config.md +0 -0
- package/coverage.md +0 -0
- package/dashboard/dist/App.d.ts +0 -0
- package/dashboard/dist/App.js +0 -0
- package/dashboard/dist/App.test.d.ts +0 -0
- package/dashboard/dist/App.test.js +0 -0
- package/dashboard/dist/api/health-diagnostics.d.ts +0 -0
- package/dashboard/dist/api/health-diagnostics.js +0 -0
- package/dashboard/dist/api/health-diagnostics.test.d.ts +0 -0
- package/dashboard/dist/api/health-diagnostics.test.js +0 -0
- package/dashboard/dist/api/index.d.ts +0 -0
- package/dashboard/dist/api/index.js +0 -0
- package/dashboard/dist/api/notes-api.d.ts +0 -0
- package/dashboard/dist/api/notes-api.js +0 -0
- package/dashboard/dist/api/notes-api.test.d.ts +0 -0
- package/dashboard/dist/api/notes-api.test.js +0 -0
- package/dashboard/dist/api/safeFetch.d.ts +0 -0
- package/dashboard/dist/api/safeFetch.js +0 -0
- package/dashboard/dist/api/safeFetch.test.d.ts +0 -0
- package/dashboard/dist/api/safeFetch.test.js +0 -0
- package/dashboard/dist/api/tasks-api.d.ts +0 -0
- package/dashboard/dist/api/tasks-api.js +0 -0
- package/dashboard/dist/api/tasks-api.test.d.ts +0 -0
- package/dashboard/dist/api/tasks-api.test.js +0 -0
- package/dashboard/dist/components/ActivityFeed.d.ts +0 -0
- package/dashboard/dist/components/ActivityFeed.js +0 -0
- package/dashboard/dist/components/ActivityFeed.test.d.ts +0 -0
- package/dashboard/dist/components/ActivityFeed.test.js +0 -0
- package/dashboard/dist/components/AgentRegistryPane.d.ts +0 -0
- package/dashboard/dist/components/AgentRegistryPane.js +0 -0
- package/dashboard/dist/components/AgentRegistryPane.test.d.ts +0 -0
- package/dashboard/dist/components/AgentRegistryPane.test.js +0 -0
- package/dashboard/dist/components/AgentsPane.d.ts +0 -0
- package/dashboard/dist/components/AgentsPane.js +0 -0
- package/dashboard/dist/components/AgentsPane.test.d.ts +0 -0
- package/dashboard/dist/components/AgentsPane.test.js +0 -0
- package/dashboard/dist/components/AppPreview.d.ts +0 -0
- package/dashboard/dist/components/AppPreview.js +0 -0
- package/dashboard/dist/components/AppPreview.test.d.ts +0 -0
- package/dashboard/dist/components/AppPreview.test.js +0 -0
- package/dashboard/dist/components/AuditPane.d.ts +0 -0
- package/dashboard/dist/components/AuditPane.js +0 -0
- package/dashboard/dist/components/AuditPane.test.d.ts +0 -0
- package/dashboard/dist/components/AuditPane.test.js +0 -0
- package/dashboard/dist/components/BranchSelector.d.ts +0 -0
- package/dashboard/dist/components/BranchSelector.js +0 -0
- package/dashboard/dist/components/BranchSelector.test.d.ts +0 -0
- package/dashboard/dist/components/BranchSelector.test.js +0 -0
- package/dashboard/dist/components/BugsPane.d.ts +0 -0
- package/dashboard/dist/components/BugsPane.js +0 -0
- package/dashboard/dist/components/BugsPane.test.d.ts +0 -0
- package/dashboard/dist/components/BugsPane.test.js +0 -0
- package/dashboard/dist/components/ChatPane.d.ts +0 -0
- package/dashboard/dist/components/ChatPane.js +0 -0
- package/dashboard/dist/components/ChatPane.test.d.ts +0 -0
- package/dashboard/dist/components/ChatPane.test.js +0 -0
- package/dashboard/dist/components/CommandPalette.d.ts +0 -0
- package/dashboard/dist/components/CommandPalette.js +0 -0
- package/dashboard/dist/components/CommandPalette.test.d.ts +0 -0
- package/dashboard/dist/components/CommandPalette.test.js +0 -0
- package/dashboard/dist/components/CompliancePane.d.ts +0 -0
- package/dashboard/dist/components/CompliancePane.js +0 -0
- package/dashboard/dist/components/CompliancePane.test.d.ts +0 -0
- package/dashboard/dist/components/CompliancePane.test.js +0 -0
- package/dashboard/dist/components/ConnectionStatus.d.ts +0 -0
- package/dashboard/dist/components/ConnectionStatus.js +0 -0
- package/dashboard/dist/components/ConnectionStatus.test.d.ts +0 -0
- package/dashboard/dist/components/ConnectionStatus.test.js +0 -0
- package/dashboard/dist/components/ContainerSecurityPane.d.ts +45 -0
- package/dashboard/dist/components/ContainerSecurityPane.js +44 -0
- package/dashboard/dist/components/ContainerSecurityPane.test.d.ts +1 -0
- package/dashboard/dist/components/ContainerSecurityPane.test.js +153 -0
- package/dashboard/dist/components/DeviceFrame.d.ts +0 -0
- package/dashboard/dist/components/DeviceFrame.js +0 -0
- package/dashboard/dist/components/DeviceFrame.test.d.ts +0 -0
- package/dashboard/dist/components/DeviceFrame.test.js +0 -0
- package/dashboard/dist/components/DocsPane.d.ts +0 -0
- package/dashboard/dist/components/DocsPane.js +0 -0
- package/dashboard/dist/components/DocsPane.test.d.ts +0 -0
- package/dashboard/dist/components/DocsPane.test.js +0 -0
- package/dashboard/dist/components/EnvironmentBadge.d.ts +0 -0
- package/dashboard/dist/components/EnvironmentBadge.js +0 -0
- package/dashboard/dist/components/EnvironmentBadge.test.d.ts +0 -0
- package/dashboard/dist/components/EnvironmentBadge.test.js +0 -0
- package/dashboard/dist/components/FocusIndicator.d.ts +0 -0
- package/dashboard/dist/components/FocusIndicator.js +0 -0
- package/dashboard/dist/components/FocusIndicator.test.d.ts +0 -0
- package/dashboard/dist/components/FocusIndicator.test.js +0 -0
- package/dashboard/dist/components/GitHubPane.d.ts +0 -0
- package/dashboard/dist/components/GitHubPane.js +0 -0
- package/dashboard/dist/components/GitHubPane.test.d.ts +0 -0
- package/dashboard/dist/components/GitHubPane.test.js +0 -0
- package/dashboard/dist/components/HealthPane.d.ts +0 -0
- package/dashboard/dist/components/HealthPane.js +0 -0
- package/dashboard/dist/components/HealthPane.test.d.ts +0 -0
- package/dashboard/dist/components/HealthPane.test.js +0 -0
- package/dashboard/dist/components/KeyboardHelp.d.ts +0 -0
- package/dashboard/dist/components/KeyboardHelp.js +0 -0
- package/dashboard/dist/components/KeyboardHelp.test.d.ts +0 -0
- package/dashboard/dist/components/KeyboardHelp.test.js +0 -0
- package/dashboard/dist/components/LogSearch.d.ts +0 -0
- package/dashboard/dist/components/LogSearch.js +0 -0
- package/dashboard/dist/components/LogSearch.test.d.ts +0 -0
- package/dashboard/dist/components/LogSearch.test.js +0 -0
- package/dashboard/dist/components/LogStream.d.ts +0 -0
- package/dashboard/dist/components/LogStream.js +0 -0
- package/dashboard/dist/components/LogStream.test.d.ts +0 -0
- package/dashboard/dist/components/LogStream.test.js +0 -0
- package/dashboard/dist/components/LogsPane.d.ts +0 -0
- package/dashboard/dist/components/LogsPane.js +0 -0
- package/dashboard/dist/components/LogsPane.test.d.ts +0 -0
- package/dashboard/dist/components/LogsPane.test.js +0 -0
- package/dashboard/dist/components/PhasesPane.d.ts +0 -0
- package/dashboard/dist/components/PhasesPane.js +0 -0
- package/dashboard/dist/components/PhasesPane.test.d.ts +0 -0
- package/dashboard/dist/components/PhasesPane.test.js +0 -0
- package/dashboard/dist/components/PlanSync.d.ts +0 -0
- package/dashboard/dist/components/PlanSync.js +0 -0
- package/dashboard/dist/components/PlanSync.test.d.ts +0 -0
- package/dashboard/dist/components/PlanSync.test.js +0 -0
- package/dashboard/dist/components/PlanView.d.ts +0 -0
- package/dashboard/dist/components/PlanView.js +0 -0
- package/dashboard/dist/components/PlanView.test.d.ts +0 -0
- package/dashboard/dist/components/PlanView.test.js +0 -0
- package/dashboard/dist/components/PreviewPane.d.ts +0 -0
- package/dashboard/dist/components/PreviewPane.js +0 -0
- package/dashboard/dist/components/PreviewPane.test.d.ts +0 -0
- package/dashboard/dist/components/PreviewPane.test.js +0 -0
- package/dashboard/dist/components/PreviewPanel.d.ts +0 -0
- package/dashboard/dist/components/PreviewPanel.js +0 -0
- package/dashboard/dist/components/PreviewPanel.test.d.ts +0 -0
- package/dashboard/dist/components/PreviewPanel.test.js +0 -0
- package/dashboard/dist/components/ProjectCard.d.ts +0 -0
- package/dashboard/dist/components/ProjectCard.js +0 -0
- package/dashboard/dist/components/ProjectCard.test.d.ts +0 -0
- package/dashboard/dist/components/ProjectCard.test.js +0 -0
- package/dashboard/dist/components/ProjectDetail.d.ts +0 -0
- package/dashboard/dist/components/ProjectDetail.js +0 -0
- package/dashboard/dist/components/ProjectDetail.test.d.ts +0 -0
- package/dashboard/dist/components/ProjectDetail.test.js +0 -0
- package/dashboard/dist/components/ProjectList.d.ts +0 -0
- package/dashboard/dist/components/ProjectList.js +0 -0
- package/dashboard/dist/components/ProjectList.test.d.ts +0 -0
- package/dashboard/dist/components/ProjectList.test.js +0 -0
- package/dashboard/dist/components/QualityGatePane.d.ts +0 -0
- package/dashboard/dist/components/QualityGatePane.js +0 -0
- package/dashboard/dist/components/QualityGatePane.test.d.ts +0 -0
- package/dashboard/dist/components/QualityGatePane.test.js +0 -0
- package/dashboard/dist/components/QualityPane.d.ts +0 -0
- package/dashboard/dist/components/QualityPane.js +0 -0
- package/dashboard/dist/components/QualityPane.test.d.ts +0 -0
- package/dashboard/dist/components/QualityPane.test.js +0 -0
- package/dashboard/dist/components/RouterPane.d.ts +0 -0
- package/dashboard/dist/components/RouterPane.js +0 -0
- package/dashboard/dist/components/RouterPane.test.d.ts +0 -0
- package/dashboard/dist/components/RouterPane.test.js +0 -0
- package/dashboard/dist/components/SSOPane.d.ts +0 -0
- package/dashboard/dist/components/SSOPane.js +0 -0
- package/dashboard/dist/components/SSOPane.test.d.ts +0 -0
- package/dashboard/dist/components/SSOPane.test.js +0 -0
- package/dashboard/dist/components/ServicesPane.d.ts +0 -0
- package/dashboard/dist/components/ServicesPane.js +0 -0
- package/dashboard/dist/components/ServicesPane.test.d.ts +0 -0
- package/dashboard/dist/components/ServicesPane.test.js +0 -0
- package/dashboard/dist/components/SettingsPanel.d.ts +0 -0
- package/dashboard/dist/components/SettingsPanel.js +0 -0
- package/dashboard/dist/components/SettingsPanel.test.d.ts +0 -0
- package/dashboard/dist/components/SettingsPanel.test.js +0 -0
- package/dashboard/dist/components/StatusBar.d.ts +0 -0
- package/dashboard/dist/components/StatusBar.js +0 -0
- package/dashboard/dist/components/StatusBar.test.d.ts +0 -0
- package/dashboard/dist/components/StatusBar.test.js +0 -0
- package/dashboard/dist/components/StatusPane.d.ts +0 -0
- package/dashboard/dist/components/StatusPane.js +0 -0
- package/dashboard/dist/components/StatusPane.test.d.ts +0 -0
- package/dashboard/dist/components/StatusPane.test.js +0 -0
- package/dashboard/dist/components/TaskBoard.d.ts +0 -0
- package/dashboard/dist/components/TaskBoard.js +0 -0
- package/dashboard/dist/components/TaskBoard.test.d.ts +0 -0
- package/dashboard/dist/components/TaskBoard.test.js +0 -0
- package/dashboard/dist/components/TaskCard.d.ts +0 -0
- package/dashboard/dist/components/TaskCard.js +0 -0
- package/dashboard/dist/components/TaskCard.test.d.ts +0 -0
- package/dashboard/dist/components/TaskCard.test.js +0 -0
- package/dashboard/dist/components/TaskDetail.d.ts +0 -0
- package/dashboard/dist/components/TaskDetail.js +0 -0
- package/dashboard/dist/components/TaskDetail.test.d.ts +0 -0
- package/dashboard/dist/components/TaskDetail.test.js +0 -0
- package/dashboard/dist/components/TaskFilter.d.ts +0 -0
- package/dashboard/dist/components/TaskFilter.js +0 -0
- package/dashboard/dist/components/TaskFilter.test.d.ts +0 -0
- package/dashboard/dist/components/TaskFilter.test.js +0 -0
- package/dashboard/dist/components/TeamPanel.d.ts +0 -0
- package/dashboard/dist/components/TeamPanel.js +0 -0
- package/dashboard/dist/components/TeamPanel.test.d.ts +0 -0
- package/dashboard/dist/components/TeamPanel.test.js +0 -0
- package/dashboard/dist/components/TeamPresence.d.ts +0 -0
- package/dashboard/dist/components/TeamPresence.js +0 -0
- package/dashboard/dist/components/TeamPresence.test.d.ts +0 -0
- package/dashboard/dist/components/TeamPresence.test.js +0 -0
- package/dashboard/dist/components/UpdateBanner.d.ts +0 -0
- package/dashboard/dist/components/UpdateBanner.js +0 -0
- package/dashboard/dist/components/UpdateBanner.test.d.ts +0 -0
- package/dashboard/dist/components/UpdateBanner.test.js +0 -0
- package/dashboard/dist/components/UsagePane.d.ts +0 -0
- package/dashboard/dist/components/UsagePane.js +0 -0
- package/dashboard/dist/components/UsagePane.test.d.ts +0 -0
- package/dashboard/dist/components/UsagePane.test.js +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.d.ts +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.js +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.test.d.ts +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.test.js +0 -0
- package/dashboard/dist/components/WorkspacePane.d.ts +0 -0
- package/dashboard/dist/components/WorkspacePane.js +0 -0
- package/dashboard/dist/components/WorkspacePane.test.d.ts +0 -0
- package/dashboard/dist/components/WorkspacePane.test.js +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.d.ts +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.js +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.test.d.ts +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.test.js +0 -0
- package/dashboard/dist/components/accessibility.test.d.ts +0 -0
- package/dashboard/dist/components/accessibility.test.js +0 -0
- package/dashboard/dist/components/layout/Header.d.ts +0 -0
- package/dashboard/dist/components/layout/Header.js +0 -0
- package/dashboard/dist/components/layout/Header.test.d.ts +0 -0
- package/dashboard/dist/components/layout/Header.test.js +0 -0
- package/dashboard/dist/components/layout/MobileNav.d.ts +0 -0
- package/dashboard/dist/components/layout/MobileNav.js +0 -0
- package/dashboard/dist/components/layout/MobileNav.test.d.ts +0 -0
- package/dashboard/dist/components/layout/MobileNav.test.js +0 -0
- package/dashboard/dist/components/layout/Shell.d.ts +0 -0
- package/dashboard/dist/components/layout/Shell.js +0 -0
- package/dashboard/dist/components/layout/Shell.test.d.ts +0 -0
- package/dashboard/dist/components/layout/Shell.test.js +0 -0
- package/dashboard/dist/components/layout/Sidebar.d.ts +0 -0
- package/dashboard/dist/components/layout/Sidebar.js +0 -0
- package/dashboard/dist/components/layout/Sidebar.test.d.ts +0 -0
- package/dashboard/dist/components/layout/Sidebar.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.js +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.js +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.js +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentList.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentList.js +0 -0
- package/dashboard/dist/components/orchestration/AgentList.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentList.test.js +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.d.ts +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.js +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.test.js +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.d.ts +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.js +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.test.js +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.d.ts +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.js +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.test.js +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.d.ts +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.js +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.test.js +0 -0
- package/dashboard/dist/components/orchestration/index.d.ts +0 -0
- package/dashboard/dist/components/orchestration/index.js +0 -0
- package/dashboard/dist/components/performance.test.d.ts +0 -0
- package/dashboard/dist/components/performance.test.js +0 -0
- package/dashboard/dist/components/responsive.test.d.ts +0 -0
- package/dashboard/dist/components/responsive.test.js +0 -0
- package/dashboard/dist/components/ui/Badge.d.ts +0 -0
- package/dashboard/dist/components/ui/Badge.js +0 -0
- package/dashboard/dist/components/ui/Badge.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Badge.test.js +0 -0
- package/dashboard/dist/components/ui/Button.d.ts +0 -0
- package/dashboard/dist/components/ui/Button.js +0 -0
- package/dashboard/dist/components/ui/Button.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Button.test.js +0 -0
- package/dashboard/dist/components/ui/Card.d.ts +0 -0
- package/dashboard/dist/components/ui/Card.js +0 -0
- package/dashboard/dist/components/ui/Card.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Card.test.js +0 -0
- package/dashboard/dist/components/ui/Dropdown.d.ts +0 -0
- package/dashboard/dist/components/ui/Dropdown.js +0 -0
- package/dashboard/dist/components/ui/Dropdown.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Dropdown.test.js +0 -0
- package/dashboard/dist/components/ui/EmptyState.d.ts +0 -0
- package/dashboard/dist/components/ui/EmptyState.js +0 -0
- package/dashboard/dist/components/ui/EmptyState.test.d.ts +0 -0
- package/dashboard/dist/components/ui/EmptyState.test.js +0 -0
- package/dashboard/dist/components/ui/ErrorState.d.ts +0 -0
- package/dashboard/dist/components/ui/ErrorState.js +0 -0
- package/dashboard/dist/components/ui/ErrorState.test.d.ts +0 -0
- package/dashboard/dist/components/ui/ErrorState.test.js +0 -0
- package/dashboard/dist/components/ui/Input.d.ts +0 -0
- package/dashboard/dist/components/ui/Input.js +0 -0
- package/dashboard/dist/components/ui/Input.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Input.test.js +0 -0
- package/dashboard/dist/components/ui/Modal.d.ts +0 -0
- package/dashboard/dist/components/ui/Modal.js +0 -0
- package/dashboard/dist/components/ui/Modal.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Modal.test.js +0 -0
- package/dashboard/dist/components/ui/Skeleton.d.ts +0 -0
- package/dashboard/dist/components/ui/Skeleton.js +0 -0
- package/dashboard/dist/components/ui/Skeleton.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Skeleton.test.js +0 -0
- package/dashboard/dist/components/ui/Toast.d.ts +0 -0
- package/dashboard/dist/components/ui/Toast.js +0 -0
- package/dashboard/dist/components/ui/Toast.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Toast.test.js +0 -0
- package/dashboard/dist/hooks/useTheme.d.ts +0 -0
- package/dashboard/dist/hooks/useTheme.js +0 -0
- package/dashboard/dist/hooks/useTheme.test.d.ts +0 -0
- package/dashboard/dist/hooks/useTheme.test.js +0 -0
- package/dashboard/dist/hooks/useWebSocket.d.ts +0 -0
- package/dashboard/dist/hooks/useWebSocket.js +0 -0
- package/dashboard/dist/hooks/useWebSocket.test.d.ts +0 -0
- package/dashboard/dist/hooks/useWebSocket.test.js +0 -0
- package/dashboard/dist/index.d.ts +0 -0
- package/dashboard/dist/index.js +0 -0
- package/dashboard/dist/stores/projectStore.d.ts +0 -0
- package/dashboard/dist/stores/projectStore.js +0 -0
- package/dashboard/dist/stores/projectStore.test.d.ts +0 -0
- package/dashboard/dist/stores/projectStore.test.js +0 -0
- package/dashboard/dist/stores/uiStore.d.ts +0 -0
- package/dashboard/dist/stores/uiStore.js +0 -0
- package/dashboard/dist/stores/uiStore.test.d.ts +0 -0
- package/dashboard/dist/stores/uiStore.test.js +0 -0
- package/dashboard/dist/styles/tokens.d.ts +0 -0
- package/dashboard/dist/styles/tokens.js +0 -0
- package/dashboard/dist/styles/tokens.test.d.ts +0 -0
- package/dashboard/dist/styles/tokens.test.js +0 -0
- package/dashboard/dist/test/setup.d.ts +0 -0
- package/dashboard/dist/test/setup.js +0 -0
- package/dashboard/package.json +0 -0
- package/deploy.md +0 -0
- package/discuss.md +0 -0
- package/docker-compose.dev.yml +0 -0
- package/docs.md +0 -0
- package/edge-cases.md +0 -0
- package/export.md +0 -0
- package/help.md +0 -0
- package/import-project.md +0 -0
- package/init.md +0 -0
- package/install.sh +0 -0
- package/issues.md +0 -0
- package/new-milestone.md +0 -0
- package/new-project.md +0 -0
- package/package.json +1 -1
- package/plan.md +0 -0
- package/progress.md +0 -0
- package/quality.md +0 -0
- package/quick.md +0 -0
- package/release.md +0 -0
- package/scripts/capture-screenshots.js +0 -0
- package/scripts/docs-update.js +0 -0
- package/scripts/generate-screenshots.js +0 -0
- package/scripts/project-docs.js +0 -0
- package/scripts/vps-setup.sh +0 -0
- package/server/dashboard/index.html +0 -0
- package/server/dashboard/login.html +0 -0
- package/server/index.js +0 -0
- package/server/lib/access-control-doc.js +0 -0
- package/server/lib/access-control-doc.test.js +0 -0
- package/server/lib/access-control.js +0 -0
- package/server/lib/access-control.test.js +1 -1
- package/server/lib/adapters/base-adapter.js +0 -0
- package/server/lib/adapters/base-adapter.test.js +0 -0
- package/server/lib/adapters/claude-adapter.js +0 -0
- package/server/lib/adapters/claude-adapter.test.js +0 -0
- package/server/lib/adapters/deepseek-adapter.js +0 -0
- package/server/lib/adapters/deepseek-adapter.test.js +0 -0
- package/server/lib/adapters/openai-adapter.js +0 -0
- package/server/lib/adapters/openai-adapter.test.js +0 -0
- package/server/lib/adr-generator.js +0 -0
- package/server/lib/adr-generator.test.js +0 -0
- package/server/lib/agent-cleanup.js +0 -0
- package/server/lib/agent-cleanup.test.js +0 -0
- package/server/lib/agent-hooks.js +0 -0
- package/server/lib/agent-hooks.test.js +0 -0
- package/server/lib/agent-metadata.js +0 -0
- package/server/lib/agent-metadata.test.js +0 -0
- package/server/lib/agent-persistence.js +0 -0
- package/server/lib/agent-persistence.test.js +0 -0
- package/server/lib/agent-progress-monitor.js +0 -0
- package/server/lib/agent-progress-monitor.test.js +0 -0
- package/server/lib/agent-registry-command.js +0 -0
- package/server/lib/agent-registry-command.test.js +0 -0
- package/server/lib/agent-registry.js +0 -0
- package/server/lib/agent-registry.test.js +0 -0
- package/server/lib/agent-state.js +0 -0
- package/server/lib/agent-state.test.js +0 -0
- package/server/lib/agents-cancel-command.js +0 -0
- package/server/lib/agents-cancel-command.test.js +1 -1
- package/server/lib/agents-get-command.js +0 -0
- package/server/lib/agents-get-command.test.js +1 -1
- package/server/lib/agents-list-command.js +0 -0
- package/server/lib/agents-list-command.test.js +1 -1
- package/server/lib/agents-logs-command.js +0 -0
- package/server/lib/agents-logs-command.test.js +1 -1
- package/server/lib/agents-retry-command.js +0 -0
- package/server/lib/agents-retry-command.test.js +1 -1
- package/server/lib/api-provider.js +0 -0
- package/server/lib/api-provider.test.js +0 -0
- package/server/lib/architecture-command.js +0 -0
- package/server/lib/architecture-command.test.js +0 -0
- package/server/lib/ast-analyzer.js +0 -0
- package/server/lib/ast-analyzer.test.js +0 -0
- package/server/lib/audit-attribution.js +0 -0
- package/server/lib/audit-attribution.test.js +0 -0
- package/server/lib/audit-classifier.js +0 -0
- package/server/lib/audit-classifier.test.js +0 -0
- package/server/lib/audit-command.js +0 -0
- package/server/lib/audit-command.test.js +0 -0
- package/server/lib/audit-exporter.js +0 -0
- package/server/lib/audit-exporter.test.js +0 -0
- package/server/lib/audit-logger.js +0 -0
- package/server/lib/audit-logger.test.js +0 -0
- package/server/lib/audit-query.js +0 -0
- package/server/lib/audit-query.test.js +0 -0
- package/server/lib/audit-storage.js +0 -0
- package/server/lib/audit-storage.test.js +0 -0
- package/server/lib/auth-flow-docs.js +0 -0
- package/server/lib/auth-flow-docs.test.js +0 -0
- package/server/lib/auth-system.js +0 -0
- package/server/lib/auth-system.test.js +0 -0
- package/server/lib/auto-database.js +0 -0
- package/server/lib/autofix-command.js +0 -0
- package/server/lib/autofix-command.test.js +0 -0
- package/server/lib/autofix-engine.js +0 -0
- package/server/lib/autofix-engine.test.js +0 -0
- package/server/lib/boundary-detector.js +0 -0
- package/server/lib/boundary-detector.test.js +0 -0
- package/server/lib/branch-deployer.js +0 -0
- package/server/lib/branch-deployer.test.js +0 -0
- package/server/lib/budget-alerts.js +0 -0
- package/server/lib/budget-alerts.test.js +0 -0
- package/server/lib/budget-limits.js +0 -0
- package/server/lib/budget-limits.test.js +2 -2
- package/server/lib/budget-tracker.js +0 -0
- package/server/lib/budget-tracker.test.js +0 -0
- package/server/lib/bug-sync.js +0 -0
- package/server/lib/bug-sync.test.js +0 -0
- package/server/lib/bulk-repo-init.js +0 -0
- package/server/lib/bulk-repo-init.test.js +0 -0
- package/server/lib/candidates-tracker.js +0 -0
- package/server/lib/candidates-tracker.test.js +0 -0
- package/server/lib/checkpoint-manager.js +0 -0
- package/server/lib/checkpoint-manager.test.js +0 -0
- package/server/lib/ci-command.js +0 -0
- package/server/lib/ci-command.test.js +0 -0
- package/server/lib/circular-detector.js +0 -0
- package/server/lib/circular-detector.test.js +0 -0
- package/server/lib/claude-injector.js +0 -0
- package/server/lib/claude-injector.test.js +0 -0
- package/server/lib/cli-detector.js +0 -0
- package/server/lib/cli-detector.test.js +0 -0
- package/server/lib/cli-provider.js +0 -0
- package/server/lib/cli-provider.test.js +0 -0
- package/server/lib/code-gate/bypass-logger.js +129 -0
- package/server/lib/code-gate/bypass-logger.test.js +142 -0
- package/server/lib/code-gate/gate-command.js +114 -0
- package/server/lib/code-gate/gate-command.test.js +111 -0
- package/server/lib/code-gate/gate-config.js +163 -0
- package/server/lib/code-gate/gate-config.test.js +181 -0
- package/server/lib/code-gate/gate-engine.js +193 -0
- package/server/lib/code-gate/gate-engine.test.js +258 -0
- package/server/lib/code-gate/gate-reporter.js +123 -0
- package/server/lib/code-gate/gate-reporter.test.js +159 -0
- package/server/lib/code-gate/hooks-generator.js +149 -0
- package/server/lib/code-gate/hooks-generator.test.js +142 -0
- package/server/lib/code-gate/llm-reviewer.js +176 -0
- package/server/lib/code-gate/llm-reviewer.test.js +161 -0
- package/server/lib/code-gate/push-gate.js +133 -0
- package/server/lib/code-gate/push-gate.test.js +190 -0
- package/server/lib/code-gate/rules/architecture-rules.js +228 -0
- package/server/lib/code-gate/rules/architecture-rules.test.js +155 -0
- package/server/lib/code-gate/rules/client-rules.js +120 -0
- package/server/lib/code-gate/rules/client-rules.test.js +121 -0
- package/server/lib/code-gate/rules/config-rules.js +140 -0
- package/server/lib/code-gate/rules/config-rules.test.js +103 -0
- package/server/lib/code-gate/rules/database-rules.js +158 -0
- package/server/lib/code-gate/rules/database-rules.test.js +119 -0
- package/server/lib/code-gate/rules/docker-rules.js +201 -0
- package/server/lib/code-gate/rules/docker-rules.test.js +104 -0
- package/server/lib/code-gate/rules/quality-rules.js +304 -0
- package/server/lib/code-gate/rules/quality-rules.test.js +199 -0
- package/server/lib/code-gate/rules/security-rules.js +228 -0
- package/server/lib/code-gate/rules/security-rules.test.js +131 -0
- package/server/lib/code-gate/rules/structure-rules.js +155 -0
- package/server/lib/code-gate/rules/structure-rules.test.js +107 -0
- package/server/lib/code-gate/rules/test-rules.js +93 -0
- package/server/lib/code-gate/rules/test-rules.test.js +97 -0
- package/server/lib/code-gate/typescript-gate.js +128 -0
- package/server/lib/code-gate/typescript-gate.test.js +131 -0
- package/server/lib/code-generator.js +0 -0
- package/server/lib/code-generator.test.js +1 -1
- package/server/lib/cohesion-analyzer.js +0 -0
- package/server/lib/cohesion-analyzer.test.js +0 -0
- package/server/lib/compliance/control-mapper.js +0 -0
- package/server/lib/compliance/control-mapper.test.js +0 -0
- package/server/lib/compliance/evidence-linker.js +0 -0
- package/server/lib/compliance/evidence-linker.test.js +0 -0
- package/server/lib/compliance/gdpr-checklist.js +0 -0
- package/server/lib/compliance/gdpr-checklist.test.js +0 -0
- package/server/lib/compliance/hipaa-checklist.js +0 -0
- package/server/lib/compliance/hipaa-checklist.test.js +0 -0
- package/server/lib/compliance/iso27001-checklist.js +0 -0
- package/server/lib/compliance/iso27001-checklist.test.js +0 -0
- package/server/lib/compliance/multi-framework-reporter.js +0 -0
- package/server/lib/compliance/multi-framework-reporter.test.js +0 -0
- package/server/lib/compliance/pci-dss-checklist.js +0 -0
- package/server/lib/compliance/pci-dss-checklist.test.js +0 -0
- package/server/lib/compliance/trust-centre.js +0 -0
- package/server/lib/compliance/trust-centre.test.js +0 -0
- package/server/lib/compliance-checklist.js +0 -0
- package/server/lib/compliance-checklist.test.js +0 -0
- package/server/lib/compliance-command.js +0 -0
- package/server/lib/compliance-command.test.js +0 -0
- package/server/lib/compliance-reporter.js +0 -0
- package/server/lib/compliance-reporter.test.js +0 -0
- package/server/lib/config.js +0 -0
- package/server/lib/config.test.js +0 -0
- package/server/lib/consensus-engine.js +0 -0
- package/server/lib/consensus-engine.test.js +0 -0
- package/server/lib/container-orchestrator.js +0 -0
- package/server/lib/container-orchestrator.test.js +0 -0
- package/server/lib/context-builder.js +0 -0
- package/server/lib/context-builder.test.js +0 -0
- package/server/lib/contract-testing.js +0 -0
- package/server/lib/contract-testing.test.js +0 -0
- package/server/lib/conversion-planner.js +0 -0
- package/server/lib/conversion-planner.test.js +0 -0
- package/server/lib/convert-command.js +0 -0
- package/server/lib/convert-command.test.js +0 -0
- package/server/lib/cost-command.js +0 -0
- package/server/lib/cost-command.test.js +1 -1
- package/server/lib/cost-optimizer.js +0 -0
- package/server/lib/cost-optimizer.test.js +1 -1
- package/server/lib/cost-projections.js +0 -0
- package/server/lib/cost-projections.test.js +1 -1
- package/server/lib/cost-reports.js +0 -0
- package/server/lib/cost-reports.test.js +1 -1
- package/server/lib/cost-tracker.js +0 -0
- package/server/lib/cost-tracker.test.js +1 -1
- package/server/lib/coupling-calculator.js +0 -0
- package/server/lib/coupling-calculator.test.js +0 -0
- package/server/lib/coverage-threshold.js +0 -0
- package/server/lib/coverage-threshold.test.js +0 -0
- package/server/lib/crypto-patterns.js +0 -0
- package/server/lib/crypto-patterns.test.js +1 -1
- package/server/lib/dashboard/api-server.js +0 -0
- package/server/lib/dashboard/api-server.test.js +0 -0
- package/server/lib/dashboard/health-api.js +0 -0
- package/server/lib/dashboard/health-api.test.js +0 -0
- package/server/lib/dashboard/notes-api.js +0 -0
- package/server/lib/dashboard/notes-api.test.js +0 -0
- package/server/lib/dashboard/router-api.js +0 -0
- package/server/lib/dashboard/router-api.test.js +0 -0
- package/server/lib/dashboard/tasks-api.js +0 -0
- package/server/lib/dashboard/tasks-api.test.js +0 -0
- package/server/lib/dashboard/tlc-introspection.js +0 -0
- package/server/lib/dashboard/tlc-introspection.test.js +0 -0
- package/server/lib/dashboard/version-api.js +0 -0
- package/server/lib/dashboard/version-api.test.js +0 -0
- package/server/lib/dashboard/websocket-server.js +0 -0
- package/server/lib/dashboard/websocket-server.test.js +0 -0
- package/server/lib/data-flow-doc.js +0 -0
- package/server/lib/data-flow-doc.test.js +0 -0
- package/server/lib/debug.test.js +0 -0
- package/server/lib/dependency-graph.js +0 -0
- package/server/lib/dependency-graph.test.js +0 -0
- package/server/lib/dependency-update.js +0 -0
- package/server/lib/dependency-update.test.js +0 -0
- package/server/lib/deploy/branch-classifier.js +0 -0
- package/server/lib/deploy/branch-classifier.test.js +0 -0
- package/server/lib/deploy/deployment-approval.js +0 -0
- package/server/lib/deploy/deployment-approval.test.js +0 -0
- package/server/lib/deploy/deployment-audit.js +0 -0
- package/server/lib/deploy/deployment-audit.test.js +0 -0
- package/server/lib/deploy/deployment-executor.js +0 -0
- package/server/lib/deploy/deployment-executor.test.js +0 -0
- package/server/lib/deploy/deployment-rules.js +0 -0
- package/server/lib/deploy/deployment-rules.test.js +0 -0
- package/server/lib/deploy/rollback-manager.js +0 -0
- package/server/lib/deploy/rollback-manager.test.js +0 -0
- package/server/lib/deploy/security-gates.js +0 -0
- package/server/lib/deploy/security-gates.test.js +0 -0
- package/server/lib/deploy-command.js +0 -0
- package/server/lib/deploy-command.test.js +0 -0
- package/server/lib/design-command.js +0 -0
- package/server/lib/design-command.test.js +1 -1
- package/server/lib/design-parser.js +0 -0
- package/server/lib/design-parser.test.js +1 -1
- package/server/lib/dev-server-command.js +0 -0
- package/server/lib/dev-server-command.test.js +0 -0
- package/server/lib/dev-server-runtime.js +0 -0
- package/server/lib/dev-server-runtime.test.js +0 -0
- package/server/lib/devserver-router-api.js +0 -0
- package/server/lib/devserver-router-api.test.js +0 -0
- package/server/lib/docker-manager.js +0 -0
- package/server/lib/docker-manager.test.js +0 -0
- package/server/lib/docs-command.js +0 -0
- package/server/lib/docs-command.test.js +0 -0
- package/server/lib/docs-generator.js +0 -0
- package/server/lib/docs-generator.test.js +0 -0
- package/server/lib/duplication-detector.js +0 -0
- package/server/lib/duplication-detector.test.js +0 -0
- package/server/lib/edge-case-generator.js +0 -0
- package/server/lib/edge-case-generator.test.js +0 -0
- package/server/lib/edge-cases-command.js +0 -0
- package/server/lib/edge-cases-command.test.js +0 -0
- package/server/lib/ephemeral-storage.js +0 -0
- package/server/lib/ephemeral-storage.test.js +0 -0
- package/server/lib/evidence-collector.js +0 -0
- package/server/lib/evidence-collector.test.js +0 -0
- package/server/lib/example-generator.js +0 -0
- package/server/lib/example-generator.test.js +0 -0
- package/server/lib/example-service.js +0 -0
- package/server/lib/example-service.test.js +0 -0
- package/server/lib/export-command.js +0 -0
- package/server/lib/export-command.test.js +0 -0
- package/server/lib/file-collector.js +0 -0
- package/server/lib/file-collector.test.js +0 -0
- package/server/lib/file-watcher.js +0 -0
- package/server/lib/file-watcher.test.js +0 -0
- package/server/lib/flow-diagram-generator.js +0 -0
- package/server/lib/flow-diagram-generator.test.js +0 -0
- package/server/lib/gemini-vision.js +0 -0
- package/server/lib/gemini-vision.test.js +1 -1
- package/server/lib/github-actions.js +0 -0
- package/server/lib/github-actions.test.js +0 -0
- package/server/lib/idp-manager.js +0 -0
- package/server/lib/idp-manager.test.js +0 -0
- package/server/lib/impact-scorer.js +0 -0
- package/server/lib/impact-scorer.test.js +0 -0
- package/server/lib/input-validator.js +0 -0
- package/server/lib/input-validator.test.js +1 -1
- package/server/lib/introspect.js +0 -0
- package/server/lib/introspect.test.js +0 -0
- package/server/lib/issue-command.js +0 -0
- package/server/lib/issue-command.test.js +0 -0
- package/server/lib/issue-tracker.js +0 -0
- package/server/lib/issue-tracker.test.js +0 -0
- package/server/lib/k8s/gitops-config.js +0 -0
- package/server/lib/k8s/gitops-config.test.js +0 -0
- package/server/lib/k8s/helm-generator.js +0 -0
- package/server/lib/k8s/helm-generator.test.js +0 -0
- package/server/lib/k8s/kustomize-generator.js +0 -0
- package/server/lib/k8s/kustomize-generator.test.js +0 -0
- package/server/lib/k8s/network-policy.js +0 -0
- package/server/lib/k8s/network-policy.test.js +0 -0
- package/server/lib/k8s/pod-security.js +0 -0
- package/server/lib/k8s/pod-security.test.js +0 -0
- package/server/lib/k8s/rbac-generator.js +0 -0
- package/server/lib/k8s/rbac-generator.test.js +0 -0
- package/server/lib/k8s/resource-manager.js +0 -0
- package/server/lib/k8s/resource-manager.test.js +0 -0
- package/server/lib/k8s/secrets-encryption.js +0 -0
- package/server/lib/k8s/secrets-encryption.test.js +0 -0
- package/server/lib/litellm-client.js +0 -0
- package/server/lib/litellm-client.test.js +1 -1
- package/server/lib/litellm-command.js +0 -0
- package/server/lib/litellm-command.test.js +1 -1
- package/server/lib/litellm-config.js +0 -0
- package/server/lib/litellm-config.test.js +1 -1
- package/server/lib/log-streamer.js +0 -0
- package/server/lib/log-streamer.test.js +0 -0
- package/server/lib/mcp-format.js +0 -0
- package/server/lib/mcp-format.test.js +0 -0
- package/server/lib/memory-classifier.js +0 -0
- package/server/lib/memory-classifier.test.js +0 -0
- package/server/lib/memory-committer.js +0 -0
- package/server/lib/memory-committer.test.js +0 -0
- package/server/lib/memory-exclusion.js +0 -0
- package/server/lib/memory-exclusion.test.js +0 -0
- package/server/lib/memory-hooks.js +0 -0
- package/server/lib/memory-hooks.test.js +0 -0
- package/server/lib/memory-init.js +0 -0
- package/server/lib/memory-init.test.js +0 -0
- package/server/lib/memory-observer.js +0 -0
- package/server/lib/memory-observer.test.js +0 -0
- package/server/lib/memory-reader.js +0 -0
- package/server/lib/memory-reader.test.js +0 -0
- package/server/lib/memory-storage.js +0 -0
- package/server/lib/memory-storage.test.js +0 -0
- package/server/lib/memory-writer.js +0 -0
- package/server/lib/memory-writer.test.js +0 -0
- package/server/lib/merge-command.js +0 -0
- package/server/lib/merge-command.test.js +0 -0
- package/server/lib/mermaid-generator.js +0 -0
- package/server/lib/mermaid-generator.test.js +0 -0
- package/server/lib/messaging-patterns.js +0 -0
- package/server/lib/messaging-patterns.test.js +0 -0
- package/server/lib/mfa-handler.js +0 -0
- package/server/lib/mfa-handler.test.js +0 -0
- package/server/lib/microservice-template.js +0 -0
- package/server/lib/microservice-template.test.js +0 -0
- package/server/lib/model-pricing.js +0 -0
- package/server/lib/model-pricing.test.js +1 -1
- package/server/lib/model-router.js +0 -0
- package/server/lib/model-router.test.js +0 -0
- package/server/lib/models-command.js +0 -0
- package/server/lib/models-command.test.js +1 -1
- package/server/lib/monitoring/alert-manager.js +0 -0
- package/server/lib/monitoring/alert-manager.test.js +0 -0
- package/server/lib/monitoring/health-check.js +0 -0
- package/server/lib/monitoring/health-check.test.js +0 -0
- package/server/lib/monitoring/incident-manager.js +0 -0
- package/server/lib/monitoring/incident-manager.test.js +0 -0
- package/server/lib/monitoring/log-aggregator.js +0 -0
- package/server/lib/monitoring/log-aggregator.test.js +0 -0
- package/server/lib/monitoring/metrics-collector.js +0 -0
- package/server/lib/monitoring/metrics-collector.test.js +0 -0
- package/server/lib/monitoring/status-page.js +0 -0
- package/server/lib/monitoring/status-page.test.js +0 -0
- package/server/lib/monitoring/uptime-monitor.js +0 -0
- package/server/lib/monitoring/uptime-monitor.test.js +0 -0
- package/server/lib/network/fail2ban-config.js +0 -0
- package/server/lib/network/fail2ban-config.test.js +0 -0
- package/server/lib/network/firewall-manager.js +0 -0
- package/server/lib/network/firewall-manager.test.js +0 -0
- package/server/lib/network/geoip-filter.js +0 -0
- package/server/lib/network/geoip-filter.test.js +0 -0
- package/server/lib/network/rate-limiter.js +0 -0
- package/server/lib/network/rate-limiter.test.js +0 -0
- package/server/lib/network/request-validator.js +0 -0
- package/server/lib/network/request-validator.test.js +0 -0
- package/server/lib/network/security-headers.js +0 -0
- package/server/lib/network/security-headers.test.js +0 -0
- package/server/lib/network/tls-config.js +0 -0
- package/server/lib/network/tls-config.test.js +0 -0
- package/server/lib/new-project-microservice.js +0 -0
- package/server/lib/new-project-microservice.test.js +0 -0
- package/server/lib/oauth-flow.js +0 -0
- package/server/lib/oauth-flow.test.js +0 -0
- package/server/lib/oauth-registry.js +0 -0
- package/server/lib/oauth-registry.test.js +0 -0
- package/server/lib/openapi-generator.js +0 -0
- package/server/lib/openapi-generator.test.js +0 -0
- package/server/lib/optimize-command.js +0 -0
- package/server/lib/optimize-command.test.js +1 -1
- package/server/lib/orchestration-integration.js +0 -0
- package/server/lib/orchestration-integration.test.js +1 -1
- package/server/lib/orm-schema-parser.js +0 -0
- package/server/lib/orm-schema-parser.test.js +0 -0
- package/server/lib/output-encoder.js +0 -0
- package/server/lib/output-encoder.test.js +1 -1
- package/server/lib/output-schemas.js +0 -0
- package/server/lib/output-schemas.test.js +0 -0
- package/server/lib/overdrive-command.js +0 -0
- package/server/lib/overdrive-command.test.js +0 -0
- package/server/lib/pattern-detector.js +0 -0
- package/server/lib/pattern-detector.test.js +0 -0
- package/server/lib/plan-parser.js +0 -0
- package/server/lib/pr-report.js +0 -0
- package/server/lib/pr-report.test.js +0 -0
- package/server/lib/pr-reviewer.js +0 -0
- package/server/lib/pr-reviewer.test.js +0 -0
- package/server/lib/project-detector.js +0 -0
- package/server/lib/provider-interface.js +0 -0
- package/server/lib/provider-interface.test.js +0 -0
- package/server/lib/provider-queue.js +0 -0
- package/server/lib/provider-queue.test.js +0 -0
- package/server/lib/qa-release-task.js +184 -0
- package/server/lib/qa-release-task.test.js +326 -0
- package/server/lib/quality-command.js +0 -0
- package/server/lib/quality-command.test.js +0 -0
- package/server/lib/quality-evaluator.js +0 -0
- package/server/lib/quality-evaluator.test.js +1 -1
- package/server/lib/quality-gate-command.js +0 -0
- package/server/lib/quality-gate-command.test.js +1 -1
- package/server/lib/quality-gate-scorer.js +0 -0
- package/server/lib/quality-gate-scorer.test.js +1 -1
- package/server/lib/quality-history.js +0 -0
- package/server/lib/quality-history.test.js +1 -1
- package/server/lib/quality-presets.js +0 -0
- package/server/lib/quality-presets.test.js +1 -1
- package/server/lib/quality-retry.js +0 -0
- package/server/lib/quality-retry.test.js +1 -1
- package/server/lib/quality-scorer.js +0 -0
- package/server/lib/quality-scorer.test.js +0 -0
- package/server/lib/quality-thresholds.js +0 -0
- package/server/lib/quality-thresholds.test.js +1 -1
- package/server/lib/readme-generator.js +0 -0
- package/server/lib/readme-generator.test.js +0 -0
- package/server/lib/refactor-command.js +0 -0
- package/server/lib/refactor-command.test.js +0 -0
- package/server/lib/refactor-executor.js +0 -0
- package/server/lib/refactor-executor.test.js +0 -0
- package/server/lib/refactor-observer.js +0 -0
- package/server/lib/refactor-observer.test.js +0 -0
- package/server/lib/refactor-progress.js +0 -0
- package/server/lib/refactor-progress.test.js +0 -0
- package/server/lib/refactor-reporter.js +0 -0
- package/server/lib/refactor-reporter.test.js +0 -0
- package/server/lib/release-audit.js +298 -0
- package/server/lib/release-audit.test.js +460 -0
- package/server/lib/release-config.js +174 -0
- package/server/lib/release-config.test.js +226 -0
- package/server/lib/release-gate.js +267 -0
- package/server/lib/release-gate.test.js +366 -0
- package/server/lib/release-notifier.js +276 -0
- package/server/lib/release-notifier.test.js +298 -0
- package/server/lib/relevance-scorer.js +0 -0
- package/server/lib/relevance-scorer.test.js +0 -0
- package/server/lib/repo-dependency-tracker.js +0 -0
- package/server/lib/repo-dependency-tracker.test.js +0 -0
- package/server/lib/retention-policy.js +0 -0
- package/server/lib/retention-policy.test.js +0 -0
- package/server/lib/review-command.js +0 -0
- package/server/lib/review-command.test.js +0 -0
- package/server/lib/review-orchestrator.js +0 -0
- package/server/lib/review-orchestrator.test.js +0 -0
- package/server/lib/review-reporter.js +0 -0
- package/server/lib/review-reporter.test.js +0 -0
- package/server/lib/role-mapper.js +0 -0
- package/server/lib/role-mapper.test.js +0 -0
- package/server/lib/route-detector.js +0 -0
- package/server/lib/route-detector.test.js +0 -0
- package/server/lib/router-config.js +0 -0
- package/server/lib/router-config.test.js +0 -0
- package/server/lib/router-setup-command.js +0 -0
- package/server/lib/router-setup-command.test.js +0 -0
- package/server/lib/router-status-api.js +0 -0
- package/server/lib/router-status-api.test.js +0 -0
- package/server/lib/saml-provider.js +0 -0
- package/server/lib/saml-provider.test.js +0 -0
- package/server/lib/screenshot-capture.js +0 -0
- package/server/lib/screenshot-capture.test.js +0 -0
- package/server/lib/secure-auth.js +0 -0
- package/server/lib/secure-auth.test.js +1 -1
- package/server/lib/secure-code-command.js +0 -0
- package/server/lib/secure-code-command.test.js +1 -1
- package/server/lib/secure-errors.js +0 -0
- package/server/lib/secure-errors.test.js +1 -1
- package/server/lib/security/auth-security.js +0 -0
- package/server/lib/security/auth-security.test.js +4 -3
- package/server/lib/security/cis-benchmark.js +0 -0
- package/server/lib/security/cis-benchmark.test.js +0 -0
- package/server/lib/security/compose-templates.js +0 -0
- package/server/lib/security/compose-templates.test.js +0 -0
- package/server/lib/security/container-runtime.js +0 -0
- package/server/lib/security/container-runtime.test.js +0 -0
- package/server/lib/security/cors-validator.js +0 -0
- package/server/lib/security/cors-validator.test.js +0 -0
- package/server/lib/security/crypto-utils.js +0 -0
- package/server/lib/security/crypto-utils.test.js +0 -0
- package/server/lib/security/dockerfile-linter.js +0 -0
- package/server/lib/security/dockerfile-linter.test.js +0 -0
- package/server/lib/security/dockerfile-templates.js +0 -0
- package/server/lib/security/dockerfile-templates.test.js +0 -0
- package/server/lib/security/error-sanitizer.js +0 -0
- package/server/lib/security/error-sanitizer.test.js +0 -0
- package/server/lib/security/headers-generator.js +0 -0
- package/server/lib/security/headers-generator.test.js +0 -0
- package/server/lib/security/image-scanner.js +0 -0
- package/server/lib/security/image-scanner.test.js +0 -0
- package/server/lib/security/input-validator.js +0 -0
- package/server/lib/security/input-validator.test.js +0 -0
- package/server/lib/security/network-policy.js +0 -0
- package/server/lib/security/network-policy.test.js +0 -0
- package/server/lib/security/output-encoder.js +0 -0
- package/server/lib/security/output-encoder.test.js +0 -0
- package/server/lib/security/path-validator.js +0 -0
- package/server/lib/security/path-validator.test.js +0 -0
- package/server/lib/security/query-builder.js +0 -0
- package/server/lib/security/query-builder.test.js +0 -0
- package/server/lib/security/secret-detector.js +0 -0
- package/server/lib/security/secret-detector.test.js +0 -0
- package/server/lib/security/secrets-validator.js +0 -0
- package/server/lib/security/secrets-validator.test.js +0 -0
- package/server/lib/security-audit.js +0 -0
- package/server/lib/security-audit.test.js +0 -0
- package/server/lib/security-policy-generator.js +0 -0
- package/server/lib/security-policy-generator.test.js +0 -0
- package/server/lib/security-testing/dast-runner.js +0 -0
- package/server/lib/security-testing/dast-runner.test.js +0 -0
- package/server/lib/security-testing/dependency-scanner.js +0 -0
- package/server/lib/security-testing/dependency-scanner.test.js +0 -0
- package/server/lib/security-testing/pentest-runner.js +0 -0
- package/server/lib/security-testing/pentest-runner.test.js +0 -0
- package/server/lib/security-testing/sast-runner.js +0 -0
- package/server/lib/security-testing/sast-runner.test.js +0 -0
- package/server/lib/security-testing/secret-scanner.js +0 -0
- package/server/lib/security-testing/secret-scanner.test.js +0 -0
- package/server/lib/security-testing/security-gate.js +0 -0
- package/server/lib/security-testing/security-gate.test.js +0 -0
- package/server/lib/security-testing/security-reporter.js +0 -0
- package/server/lib/security-testing/security-reporter.test.js +0 -0
- package/server/lib/semantic-analyzer.js +0 -0
- package/server/lib/semantic-analyzer.test.js +0 -0
- package/server/lib/sensitive-detector.js +0 -0
- package/server/lib/sensitive-detector.test.js +0 -0
- package/server/lib/service-interaction-diagram.js +0 -0
- package/server/lib/service-interaction-diagram.test.js +0 -0
- package/server/lib/service-proxy.js +0 -0
- package/server/lib/service-proxy.test.js +0 -0
- package/server/lib/service-scaffold.js +0 -0
- package/server/lib/service-scaffold.test.js +0 -0
- package/server/lib/service-summary.js +0 -0
- package/server/lib/service-summary.test.js +0 -0
- package/server/lib/session-purge.js +0 -0
- package/server/lib/session-purge.test.js +0 -0
- package/server/lib/session-summary.js +0 -0
- package/server/lib/session-summary.test.js +0 -0
- package/server/lib/shared-kernel.js +0 -0
- package/server/lib/shared-kernel.test.js +0 -0
- package/server/lib/slack-notifier.js +0 -0
- package/server/lib/slack-notifier.test.js +0 -0
- package/server/lib/spec-merger.js +0 -0
- package/server/lib/spec-merger.test.js +0 -0
- package/server/lib/sso-command.js +0 -0
- package/server/lib/sso-command.test.js +0 -0
- package/server/lib/sso-session.js +0 -0
- package/server/lib/sso-session.test.js +0 -0
- package/server/lib/standards/audit-checker.js +0 -0
- package/server/lib/standards/audit-checker.test.js +0 -0
- package/server/lib/standards/cleanup-executor.js +0 -0
- package/server/lib/standards/cleanup-executor.test.js +0 -0
- package/server/lib/standards/refactor-stepper.js +0 -0
- package/server/lib/standards/refactor-stepper.test.js +0 -0
- package/server/lib/standards/standards-injector.js +0 -0
- package/server/lib/standards/standards-injector.test.js +0 -0
- package/server/lib/tag-classifier.js +154 -0
- package/server/lib/tag-classifier.test.js +240 -0
- package/server/lib/tag-release-command.js +456 -0
- package/server/lib/tag-release-command.test.js +542 -0
- package/server/lib/tag-release.js +398 -0
- package/server/lib/tag-release.test.js +478 -0
- package/server/lib/team-docs-command.js +0 -0
- package/server/lib/team-docs-command.test.js +0 -0
- package/server/lib/team-docs.js +0 -0
- package/server/lib/team-docs.test.js +0 -0
- package/server/lib/tool-detector.js +0 -0
- package/server/lib/tool-detector.test.js +0 -0
- package/server/lib/tool-rules.js +0 -0
- package/server/lib/tool-rules.test.js +0 -0
- package/server/lib/traefik-config.js +0 -0
- package/server/lib/traefik-config.test.js +0 -0
- package/server/lib/usage-command.js +0 -0
- package/server/lib/usage-command.test.js +0 -0
- package/server/lib/usage-formatter.js +0 -0
- package/server/lib/usage-formatter.test.js +0 -0
- package/server/lib/usage-history.js +0 -0
- package/server/lib/usage-history.test.js +0 -0
- package/server/lib/user-management.test.js +0 -0
- package/server/lib/vision-command.js +0 -0
- package/server/lib/vision-command.test.js +1 -1
- package/server/lib/visual-command.js +0 -0
- package/server/lib/visual-command.test.js +1 -1
- package/server/lib/visual-testing.js +0 -0
- package/server/lib/visual-testing.test.js +1 -1
- package/server/lib/vps/backup-manager.js +0 -0
- package/server/lib/vps/backup-manager.test.js +0 -0
- package/server/lib/vps/caddy-config.js +0 -0
- package/server/lib/vps/caddy-config.test.js +0 -0
- package/server/lib/vps/compose-orchestrator.js +0 -0
- package/server/lib/vps/compose-orchestrator.test.js +0 -0
- package/server/lib/vps/database-config.js +0 -0
- package/server/lib/vps/database-config.test.js +0 -0
- package/server/lib/vps/deploy-script.js +0 -0
- package/server/lib/vps/deploy-script.test.js +0 -0
- package/server/lib/vps/secrets-manager.js +0 -0
- package/server/lib/vps/secrets-manager.test.js +0 -0
- package/server/lib/vps/server-hardening.js +0 -0
- package/server/lib/vps/server-hardening.test.js +0 -0
- package/server/lib/webhook-listener.js +0 -0
- package/server/lib/webhook-listener.test.js +0 -0
- package/server/lib/webhook-tag-handler.js +154 -0
- package/server/lib/webhook-tag-handler.test.js +228 -0
- package/server/lib/websocket-server.js +0 -0
- package/server/lib/websocket-server.test.js +0 -0
- package/server/lib/workspace-command.js +0 -0
- package/server/lib/workspace-command.test.js +0 -0
- package/server/lib/workspace-config.js +0 -0
- package/server/lib/workspace-config.test.js +0 -0
- package/server/lib/workspace-docs-command.js +0 -0
- package/server/lib/workspace-docs-command.test.js +0 -0
- package/server/lib/workspace-memory.js +0 -0
- package/server/lib/workspace-memory.test.js +0 -0
- package/server/lib/workspace-scanner.js +0 -0
- package/server/lib/workspace-scanner.test.js +0 -0
- package/server/lib/workspace-test-runner.js +0 -0
- package/server/lib/workspace-test-runner.test.js +0 -0
- package/server/lib/zero-retention-command.js +0 -0
- package/server/lib/zero-retention-command.test.js +0 -0
- package/server/lib/zero-retention.js +0 -0
- package/server/lib/zero-retention.test.js +0 -0
- package/server/package-lock.json +0 -0
- package/server/package.json +0 -0
- package/server/setup.sh +0 -0
- package/server/templates/CLAUDE.md +0 -0
- package/server/templates/CODING-STANDARDS.md +0 -0
- package/server.md +0 -0
- package/start-dev.bat +0 -0
- package/start-dev.ps1 +0 -0
- package/start-dev.sh +0 -0
- package/start.md +0 -0
- package/status.md +0 -0
- package/sync.md +0 -0
- package/templates/docs-sync.yml +0 -0
- package/tlc.md +0 -0
- package/update.md +0 -0
- package/verify.md +0 -0
- package/who.md +0 -0
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Gate Engine Tests
|
|
3
|
+
*
|
|
4
|
+
* The gate engine accepts changed files and runs configurable rule sets
|
|
5
|
+
* against each file, returning pass/fail with detailed findings.
|
|
6
|
+
*/
|
|
7
|
+
import { describe, it, expect, beforeEach } from 'vitest';
|
|
8
|
+
|
|
9
|
+
const {
|
|
10
|
+
createGateEngine,
|
|
11
|
+
runGate,
|
|
12
|
+
aggregateFindings,
|
|
13
|
+
calculateScore,
|
|
14
|
+
SEVERITY,
|
|
15
|
+
} = require('./gate-engine.js');
|
|
16
|
+
|
|
17
|
+
describe('Gate Engine', () => {
|
|
18
|
+
describe('SEVERITY', () => {
|
|
19
|
+
it('defines all severity levels', () => {
|
|
20
|
+
expect(SEVERITY.BLOCK).toBe('block');
|
|
21
|
+
expect(SEVERITY.WARN).toBe('warn');
|
|
22
|
+
expect(SEVERITY.INFO).toBe('info');
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
describe('createGateEngine', () => {
|
|
27
|
+
it('creates engine with default options', () => {
|
|
28
|
+
const engine = createGateEngine();
|
|
29
|
+
expect(engine).toBeDefined();
|
|
30
|
+
expect(engine.rules).toEqual([]);
|
|
31
|
+
expect(engine.options).toBeDefined();
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it('creates engine with custom rules', () => {
|
|
35
|
+
const mockRule = { id: 'test-rule', check: () => [] };
|
|
36
|
+
const engine = createGateEngine({ rules: [mockRule] });
|
|
37
|
+
expect(engine.rules).toHaveLength(1);
|
|
38
|
+
expect(engine.rules[0].id).toBe('test-rule');
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
it('accepts ignore patterns', () => {
|
|
42
|
+
const engine = createGateEngine({ ignore: ['*.md', 'dist/*'] });
|
|
43
|
+
expect(engine.options.ignore).toEqual(['*.md', 'dist/*']);
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
describe('runGate', () => {
|
|
48
|
+
let engine;
|
|
49
|
+
|
|
50
|
+
beforeEach(() => {
|
|
51
|
+
engine = createGateEngine();
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
it('returns pass for empty changeset', async () => {
|
|
55
|
+
const result = await runGate(engine, []);
|
|
56
|
+
expect(result.passed).toBe(true);
|
|
57
|
+
expect(result.findings).toEqual([]);
|
|
58
|
+
expect(result.summary.total).toBe(0);
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
it('runs rules against each file', async () => {
|
|
62
|
+
const ruleCallCount = { count: 0 };
|
|
63
|
+
const mockRule = {
|
|
64
|
+
id: 'counter-rule',
|
|
65
|
+
check: (file, content) => {
|
|
66
|
+
ruleCallCount.count++;
|
|
67
|
+
return [];
|
|
68
|
+
},
|
|
69
|
+
};
|
|
70
|
+
engine = createGateEngine({ rules: [mockRule] });
|
|
71
|
+
|
|
72
|
+
const files = [
|
|
73
|
+
{ path: 'src/a.js', content: 'const a = 1;' },
|
|
74
|
+
{ path: 'src/b.js', content: 'const b = 2;' },
|
|
75
|
+
];
|
|
76
|
+
|
|
77
|
+
await runGate(engine, files);
|
|
78
|
+
expect(ruleCallCount.count).toBe(2);
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it('collects findings from all rules', async () => {
|
|
82
|
+
const rule1 = {
|
|
83
|
+
id: 'rule-a',
|
|
84
|
+
check: () => [
|
|
85
|
+
{ severity: 'block', rule: 'rule-a', line: 1, message: 'Issue A', fix: 'Fix A' },
|
|
86
|
+
],
|
|
87
|
+
};
|
|
88
|
+
const rule2 = {
|
|
89
|
+
id: 'rule-b',
|
|
90
|
+
check: () => [
|
|
91
|
+
{ severity: 'warn', rule: 'rule-b', line: 5, message: 'Issue B', fix: 'Fix B' },
|
|
92
|
+
],
|
|
93
|
+
};
|
|
94
|
+
engine = createGateEngine({ rules: [rule1, rule2] });
|
|
95
|
+
|
|
96
|
+
const result = await runGate(engine, [{ path: 'src/a.js', content: 'code' }]);
|
|
97
|
+
expect(result.findings).toHaveLength(2);
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
it('fails when any finding has block severity', async () => {
|
|
101
|
+
const rule = {
|
|
102
|
+
id: 'blocker',
|
|
103
|
+
check: () => [
|
|
104
|
+
{ severity: 'block', rule: 'blocker', line: 1, message: 'Blocked', fix: 'Fix it' },
|
|
105
|
+
],
|
|
106
|
+
};
|
|
107
|
+
engine = createGateEngine({ rules: [rule] });
|
|
108
|
+
|
|
109
|
+
const result = await runGate(engine, [{ path: 'src/a.js', content: 'code' }]);
|
|
110
|
+
expect(result.passed).toBe(false);
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
it('passes when findings are warn-only', async () => {
|
|
114
|
+
const rule = {
|
|
115
|
+
id: 'warner',
|
|
116
|
+
check: () => [
|
|
117
|
+
{ severity: 'warn', rule: 'warner', line: 1, message: 'Warning', fix: 'Maybe fix' },
|
|
118
|
+
],
|
|
119
|
+
};
|
|
120
|
+
engine = createGateEngine({ rules: [rule] });
|
|
121
|
+
|
|
122
|
+
const result = await runGate(engine, [{ path: 'src/a.js', content: 'code' }]);
|
|
123
|
+
expect(result.passed).toBe(true);
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
it('passes when findings are info-only', async () => {
|
|
127
|
+
const rule = {
|
|
128
|
+
id: 'informer',
|
|
129
|
+
check: () => [
|
|
130
|
+
{ severity: 'info', rule: 'informer', line: 1, message: 'FYI', fix: 'Optional' },
|
|
131
|
+
],
|
|
132
|
+
};
|
|
133
|
+
engine = createGateEngine({ rules: [rule] });
|
|
134
|
+
|
|
135
|
+
const result = await runGate(engine, [{ path: 'src/a.js', content: 'code' }]);
|
|
136
|
+
expect(result.passed).toBe(true);
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
it('attaches file path to each finding', async () => {
|
|
140
|
+
const rule = {
|
|
141
|
+
id: 'path-test',
|
|
142
|
+
check: () => [
|
|
143
|
+
{ severity: 'warn', rule: 'path-test', line: 1, message: 'X', fix: 'Y' },
|
|
144
|
+
],
|
|
145
|
+
};
|
|
146
|
+
engine = createGateEngine({ rules: [rule] });
|
|
147
|
+
|
|
148
|
+
const result = await runGate(engine, [{ path: 'src/deep/file.js', content: 'x' }]);
|
|
149
|
+
expect(result.findings[0].file).toBe('src/deep/file.js');
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
it('skips files matching ignore patterns', async () => {
|
|
153
|
+
const rule = {
|
|
154
|
+
id: 'skip-test',
|
|
155
|
+
check: () => [
|
|
156
|
+
{ severity: 'block', rule: 'skip-test', line: 1, message: 'Bad', fix: 'Fix' },
|
|
157
|
+
],
|
|
158
|
+
};
|
|
159
|
+
engine = createGateEngine({ rules: [rule], ignore: ['*.md', '*.json'] });
|
|
160
|
+
|
|
161
|
+
const files = [
|
|
162
|
+
{ path: 'README.md', content: '# Hello' },
|
|
163
|
+
{ path: 'package.json', content: '{}' },
|
|
164
|
+
{ path: 'src/app.js', content: 'code' },
|
|
165
|
+
];
|
|
166
|
+
|
|
167
|
+
const result = await runGate(engine, files);
|
|
168
|
+
// Only src/app.js should be checked
|
|
169
|
+
expect(result.findings).toHaveLength(1);
|
|
170
|
+
expect(result.findings[0].file).toBe('src/app.js');
|
|
171
|
+
});
|
|
172
|
+
|
|
173
|
+
it('includes summary with counts per severity', async () => {
|
|
174
|
+
const rule = {
|
|
175
|
+
id: 'multi',
|
|
176
|
+
check: () => [
|
|
177
|
+
{ severity: 'block', rule: 'multi', line: 1, message: 'A', fix: 'A' },
|
|
178
|
+
{ severity: 'warn', rule: 'multi', line: 2, message: 'B', fix: 'B' },
|
|
179
|
+
{ severity: 'info', rule: 'multi', line: 3, message: 'C', fix: 'C' },
|
|
180
|
+
],
|
|
181
|
+
};
|
|
182
|
+
engine = createGateEngine({ rules: [rule] });
|
|
183
|
+
|
|
184
|
+
const result = await runGate(engine, [{ path: 'x.js', content: '' }]);
|
|
185
|
+
expect(result.summary.total).toBe(3);
|
|
186
|
+
expect(result.summary.block).toBe(1);
|
|
187
|
+
expect(result.summary.warn).toBe(1);
|
|
188
|
+
expect(result.summary.info).toBe(1);
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
it('handles rule that throws gracefully', async () => {
|
|
192
|
+
const rule = {
|
|
193
|
+
id: 'crasher',
|
|
194
|
+
check: () => { throw new Error('Rule crashed'); },
|
|
195
|
+
};
|
|
196
|
+
engine = createGateEngine({ rules: [rule] });
|
|
197
|
+
|
|
198
|
+
const result = await runGate(engine, [{ path: 'x.js', content: '' }]);
|
|
199
|
+
// Should not throw - engine catches rule errors
|
|
200
|
+
expect(result).toBeDefined();
|
|
201
|
+
expect(result.findings).toHaveLength(1);
|
|
202
|
+
expect(result.findings[0].rule).toBe('crasher');
|
|
203
|
+
expect(result.findings[0].severity).toBe('warn');
|
|
204
|
+
expect(result.findings[0].message).toContain('Rule crashed');
|
|
205
|
+
});
|
|
206
|
+
|
|
207
|
+
it('measures execution duration', async () => {
|
|
208
|
+
engine = createGateEngine();
|
|
209
|
+
const result = await runGate(engine, []);
|
|
210
|
+
expect(typeof result.duration).toBe('number');
|
|
211
|
+
expect(result.duration).toBeGreaterThanOrEqual(0);
|
|
212
|
+
});
|
|
213
|
+
});
|
|
214
|
+
|
|
215
|
+
describe('aggregateFindings', () => {
|
|
216
|
+
it('groups findings by file', () => {
|
|
217
|
+
const findings = [
|
|
218
|
+
{ file: 'a.js', rule: 'r1', severity: 'block', message: 'A' },
|
|
219
|
+
{ file: 'b.js', rule: 'r2', severity: 'warn', message: 'B' },
|
|
220
|
+
{ file: 'a.js', rule: 'r3', severity: 'info', message: 'C' },
|
|
221
|
+
];
|
|
222
|
+
const grouped = aggregateFindings(findings);
|
|
223
|
+
expect(grouped['a.js']).toHaveLength(2);
|
|
224
|
+
expect(grouped['b.js']).toHaveLength(1);
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
it('returns empty object for no findings', () => {
|
|
228
|
+
const grouped = aggregateFindings([]);
|
|
229
|
+
expect(Object.keys(grouped)).toHaveLength(0);
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
describe('calculateScore', () => {
|
|
234
|
+
it('returns 100 for no findings', () => {
|
|
235
|
+
expect(calculateScore([])).toBe(100);
|
|
236
|
+
});
|
|
237
|
+
|
|
238
|
+
it('deducts points for block findings', () => {
|
|
239
|
+
const findings = [
|
|
240
|
+
{ severity: 'block' },
|
|
241
|
+
];
|
|
242
|
+
const score = calculateScore(findings);
|
|
243
|
+
expect(score).toBeLessThan(100);
|
|
244
|
+
expect(score).toBeGreaterThanOrEqual(0);
|
|
245
|
+
});
|
|
246
|
+
|
|
247
|
+
it('deducts fewer points for warnings', () => {
|
|
248
|
+
const blockFindings = [{ severity: 'block' }];
|
|
249
|
+
const warnFindings = [{ severity: 'warn' }];
|
|
250
|
+
expect(calculateScore(warnFindings)).toBeGreaterThan(calculateScore(blockFindings));
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
it('floors at zero', () => {
|
|
254
|
+
const manyFindings = Array.from({ length: 50 }, () => ({ severity: 'block' }));
|
|
255
|
+
expect(calculateScore(manyFindings)).toBe(0);
|
|
256
|
+
});
|
|
257
|
+
});
|
|
258
|
+
});
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Gate Reporter
|
|
3
|
+
*
|
|
4
|
+
* Formats gate results into clear, actionable terminal output
|
|
5
|
+
* with severity badges, fix suggestions, and summary line.
|
|
6
|
+
*
|
|
7
|
+
* @module code-gate/gate-reporter
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Format a single finding as a readable string.
|
|
12
|
+
*
|
|
13
|
+
* @param {Object} finding
|
|
14
|
+
* @param {string} finding.severity
|
|
15
|
+
* @param {string} finding.rule
|
|
16
|
+
* @param {string} finding.file
|
|
17
|
+
* @param {number} [finding.line]
|
|
18
|
+
* @param {string} finding.message
|
|
19
|
+
* @param {string} finding.fix
|
|
20
|
+
* @returns {string}
|
|
21
|
+
*/
|
|
22
|
+
function formatFinding(finding) {
|
|
23
|
+
const badge = `[${finding.severity.toUpperCase()}]`;
|
|
24
|
+
const location = finding.line ? ` (line ${finding.line})` : '';
|
|
25
|
+
const rule = finding.rule;
|
|
26
|
+
|
|
27
|
+
let output = ` ${badge} ${rule}${location}\n`;
|
|
28
|
+
output += ` ${finding.message}\n`;
|
|
29
|
+
if (finding.fix) {
|
|
30
|
+
output += ` Fix: ${finding.fix}\n`;
|
|
31
|
+
}
|
|
32
|
+
return output;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Group findings by file path.
|
|
37
|
+
*
|
|
38
|
+
* @param {Array} findings
|
|
39
|
+
* @returns {Object.<string, Array>}
|
|
40
|
+
*/
|
|
41
|
+
function groupByFile(findings) {
|
|
42
|
+
const groups = {};
|
|
43
|
+
for (const finding of findings) {
|
|
44
|
+
const key = finding.file;
|
|
45
|
+
if (!groups[key]) groups[key] = [];
|
|
46
|
+
groups[key].push(finding);
|
|
47
|
+
}
|
|
48
|
+
return groups;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* Format the summary line.
|
|
53
|
+
*
|
|
54
|
+
* @param {Object} summary - { total, block, warn, info }
|
|
55
|
+
* @param {boolean} passed
|
|
56
|
+
* @returns {string}
|
|
57
|
+
*/
|
|
58
|
+
function formatSummary(summary, passed) {
|
|
59
|
+
if (passed && summary.total === 0) {
|
|
60
|
+
return 'All clear — gate passed.';
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const parts = [];
|
|
64
|
+
if (summary.block > 0) parts.push(`${summary.block} blocking`);
|
|
65
|
+
if (summary.warn > 0) parts.push(`${summary.warn} warning${summary.warn > 1 ? 's' : ''}`);
|
|
66
|
+
if (summary.info > 0) parts.push(`${summary.info} info`);
|
|
67
|
+
|
|
68
|
+
const status = passed ? 'passed' : 'blocked';
|
|
69
|
+
return `Summary: ${parts.join(' | ')} — gate ${status}.`;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Format a complete gate report.
|
|
74
|
+
*
|
|
75
|
+
* @param {Object} result - Gate engine result
|
|
76
|
+
* @param {boolean} result.passed
|
|
77
|
+
* @param {Array} result.findings
|
|
78
|
+
* @param {Object} result.summary
|
|
79
|
+
* @returns {string}
|
|
80
|
+
*/
|
|
81
|
+
function formatReport(result) {
|
|
82
|
+
const { passed, findings, summary } = result;
|
|
83
|
+
|
|
84
|
+
let report = '';
|
|
85
|
+
|
|
86
|
+
// Header
|
|
87
|
+
const status = passed ? 'Passed' : 'Blocked';
|
|
88
|
+
report += `TLC Code Gate — ${status}\n`;
|
|
89
|
+
report += '─'.repeat(42) + '\n\n';
|
|
90
|
+
|
|
91
|
+
if (findings.length === 0) {
|
|
92
|
+
report += 'All clear — no issues found.\n\n';
|
|
93
|
+
report += formatSummary(summary, passed) + '\n';
|
|
94
|
+
return report;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// Group and display findings by file
|
|
98
|
+
const grouped = groupByFile(findings);
|
|
99
|
+
for (const [file, fileFindings] of Object.entries(grouped)) {
|
|
100
|
+
report += `${file}\n`;
|
|
101
|
+
for (const finding of fileFindings) {
|
|
102
|
+
report += formatFinding(finding);
|
|
103
|
+
}
|
|
104
|
+
report += '\n';
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// Summary
|
|
108
|
+
report += formatSummary(summary, passed) + '\n';
|
|
109
|
+
|
|
110
|
+
// Bypass hint (only when blocked)
|
|
111
|
+
if (!passed) {
|
|
112
|
+
report += 'Fix blocking issues or use --no-verify (logged).\n';
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
return report;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
module.exports = {
|
|
119
|
+
formatReport,
|
|
120
|
+
formatSummary,
|
|
121
|
+
formatFinding,
|
|
122
|
+
groupByFile,
|
|
123
|
+
};
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Gate Reporter Tests
|
|
3
|
+
*
|
|
4
|
+
* Formats gate results into clear, actionable terminal output
|
|
5
|
+
* with severity badges, fix suggestions, and summary.
|
|
6
|
+
*/
|
|
7
|
+
import { describe, it, expect } from 'vitest';
|
|
8
|
+
|
|
9
|
+
const {
|
|
10
|
+
formatReport,
|
|
11
|
+
formatSummary,
|
|
12
|
+
formatFinding,
|
|
13
|
+
groupByFile,
|
|
14
|
+
} = require('./gate-reporter.js');
|
|
15
|
+
|
|
16
|
+
describe('Gate Reporter', () => {
|
|
17
|
+
describe('formatFinding', () => {
|
|
18
|
+
it('formats a block finding with line number', () => {
|
|
19
|
+
const finding = {
|
|
20
|
+
severity: 'block',
|
|
21
|
+
rule: 'no-eval',
|
|
22
|
+
file: 'src/app.js',
|
|
23
|
+
line: 12,
|
|
24
|
+
message: "eval() is not allowed",
|
|
25
|
+
fix: 'Use a safe alternative',
|
|
26
|
+
};
|
|
27
|
+
const output = formatFinding(finding);
|
|
28
|
+
expect(output).toContain('[BLOCK]');
|
|
29
|
+
expect(output).toContain('no-eval');
|
|
30
|
+
expect(output).toContain('line 12');
|
|
31
|
+
expect(output).toContain('eval()');
|
|
32
|
+
expect(output).toContain('Use a safe alternative');
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
it('formats a warn finding', () => {
|
|
36
|
+
const finding = {
|
|
37
|
+
severity: 'warn',
|
|
38
|
+
rule: 'max-function-length',
|
|
39
|
+
file: 'src/big.js',
|
|
40
|
+
line: 45,
|
|
41
|
+
message: 'Function too long',
|
|
42
|
+
fix: 'Extract helper functions',
|
|
43
|
+
};
|
|
44
|
+
const output = formatFinding(finding);
|
|
45
|
+
expect(output).toContain('[WARN]');
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
it('formats info finding', () => {
|
|
49
|
+
const finding = {
|
|
50
|
+
severity: 'info',
|
|
51
|
+
rule: 'docs-hint',
|
|
52
|
+
file: 'src/x.js',
|
|
53
|
+
message: 'Consider adding docs',
|
|
54
|
+
fix: 'Add JSDoc',
|
|
55
|
+
};
|
|
56
|
+
const output = formatFinding(finding);
|
|
57
|
+
expect(output).toContain('[INFO]');
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
it('handles finding without line number', () => {
|
|
61
|
+
const finding = {
|
|
62
|
+
severity: 'block',
|
|
63
|
+
rule: 'require-test-file',
|
|
64
|
+
file: 'src/x.js',
|
|
65
|
+
message: 'No test file found',
|
|
66
|
+
fix: 'Create test file',
|
|
67
|
+
};
|
|
68
|
+
const output = formatFinding(finding);
|
|
69
|
+
expect(output).not.toContain('line');
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
describe('groupByFile', () => {
|
|
74
|
+
it('groups findings by file path', () => {
|
|
75
|
+
const findings = [
|
|
76
|
+
{ file: 'a.js', rule: 'r1', severity: 'block', message: 'A' },
|
|
77
|
+
{ file: 'b.js', rule: 'r2', severity: 'warn', message: 'B' },
|
|
78
|
+
{ file: 'a.js', rule: 'r3', severity: 'info', message: 'C' },
|
|
79
|
+
];
|
|
80
|
+
const groups = groupByFile(findings);
|
|
81
|
+
expect(Object.keys(groups)).toHaveLength(2);
|
|
82
|
+
expect(groups['a.js']).toHaveLength(2);
|
|
83
|
+
expect(groups['b.js']).toHaveLength(1);
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
describe('formatSummary', () => {
|
|
88
|
+
it('shows blocking count and pass status', () => {
|
|
89
|
+
const summary = { total: 0, block: 0, warn: 0, info: 0 };
|
|
90
|
+
const output = formatSummary(summary, true);
|
|
91
|
+
expect(output).toContain('passed');
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it('shows blocking message when blocked', () => {
|
|
95
|
+
const summary = { total: 3, block: 2, warn: 1, info: 0 };
|
|
96
|
+
const output = formatSummary(summary, false);
|
|
97
|
+
expect(output).toContain('2 blocking');
|
|
98
|
+
expect(output).toContain('1 warning');
|
|
99
|
+
expect(output).toContain('blocked');
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
describe('formatReport', () => {
|
|
104
|
+
it('formats complete report with header', () => {
|
|
105
|
+
const result = {
|
|
106
|
+
passed: false,
|
|
107
|
+
findings: [
|
|
108
|
+
{ file: 'src/app.js', severity: 'block', rule: 'no-eval', line: 5, message: 'eval found', fix: 'Remove eval' },
|
|
109
|
+
],
|
|
110
|
+
summary: { total: 1, block: 1, warn: 0, info: 0 },
|
|
111
|
+
};
|
|
112
|
+
const output = formatReport(result);
|
|
113
|
+
expect(output).toContain('Code Gate');
|
|
114
|
+
expect(output).toContain('src/app.js');
|
|
115
|
+
expect(output).toContain('[BLOCK]');
|
|
116
|
+
expect(output).toContain('blocked');
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
it('formats all-clear report', () => {
|
|
120
|
+
const result = {
|
|
121
|
+
passed: true,
|
|
122
|
+
findings: [],
|
|
123
|
+
summary: { total: 0, block: 0, warn: 0, info: 0 },
|
|
124
|
+
};
|
|
125
|
+
const output = formatReport(result);
|
|
126
|
+
expect(output).toContain('passed');
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
it('groups findings by file in report', () => {
|
|
130
|
+
const result = {
|
|
131
|
+
passed: false,
|
|
132
|
+
findings: [
|
|
133
|
+
{ file: 'a.js', severity: 'block', rule: 'r1', message: 'X', fix: 'Y' },
|
|
134
|
+
{ file: 'b.js', severity: 'block', rule: 'r2', message: 'X', fix: 'Y' },
|
|
135
|
+
{ file: 'a.js', severity: 'warn', rule: 'r3', message: 'X', fix: 'Y' },
|
|
136
|
+
],
|
|
137
|
+
summary: { total: 3, block: 2, warn: 1, info: 0 },
|
|
138
|
+
};
|
|
139
|
+
const output = formatReport(result);
|
|
140
|
+
// a.js should appear before its findings
|
|
141
|
+
const aIndex = output.indexOf('a.js');
|
|
142
|
+
const bIndex = output.indexOf('b.js');
|
|
143
|
+
expect(aIndex).toBeGreaterThan(-1);
|
|
144
|
+
expect(bIndex).toBeGreaterThan(-1);
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
it('includes bypass hint in blocked report', () => {
|
|
148
|
+
const result = {
|
|
149
|
+
passed: false,
|
|
150
|
+
findings: [
|
|
151
|
+
{ file: 'x.js', severity: 'block', rule: 'r1', message: 'Bad', fix: 'Fix' },
|
|
152
|
+
],
|
|
153
|
+
summary: { total: 1, block: 1, warn: 0, info: 0 },
|
|
154
|
+
};
|
|
155
|
+
const output = formatReport(result);
|
|
156
|
+
expect(output).toContain('--no-verify');
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
});
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hooks Generator
|
|
3
|
+
*
|
|
4
|
+
* Generates and installs git hooks that run the TLC code gate.
|
|
5
|
+
* Hooks are portable sh scripts (not bash-specific).
|
|
6
|
+
*
|
|
7
|
+
* @module code-gate/hooks-generator
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
const path = require('path');
|
|
11
|
+
const fs = require('fs');
|
|
12
|
+
|
|
13
|
+
/** Marker comment to identify TLC-generated hooks */
|
|
14
|
+
const TLC_HOOK_MARKER = '# TLC Code Gate';
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Generate a pre-commit hook script.
|
|
18
|
+
* Runs fast static analysis (< 3s) on staged files.
|
|
19
|
+
*
|
|
20
|
+
* @returns {string} Shell script content
|
|
21
|
+
*/
|
|
22
|
+
function generatePreCommitHook() {
|
|
23
|
+
return `#!/bin/sh
|
|
24
|
+
${TLC_HOOK_MARKER} — pre-commit
|
|
25
|
+
# Runs static code gate on staged files.
|
|
26
|
+
# To bypass: git commit --no-verify (bypass is logged)
|
|
27
|
+
|
|
28
|
+
# Get the project root
|
|
29
|
+
PROJECT_ROOT="$(git rev-parse --show-toplevel)"
|
|
30
|
+
|
|
31
|
+
# Run the TLC gate check on staged files
|
|
32
|
+
if command -v node > /dev/null 2>&1; then
|
|
33
|
+
node "$PROJECT_ROOT/node_modules/.bin/tlc-gate" check --hook pre-commit
|
|
34
|
+
EXIT_CODE=$?
|
|
35
|
+
|
|
36
|
+
if [ $EXIT_CODE -ne 0 ]; then
|
|
37
|
+
echo ""
|
|
38
|
+
echo "Commit blocked by TLC Code Gate."
|
|
39
|
+
echo "Fix the issues above or use: git commit --no-verify"
|
|
40
|
+
exit 1
|
|
41
|
+
fi
|
|
42
|
+
else
|
|
43
|
+
echo "Warning: Node.js not found. Skipping TLC Code Gate."
|
|
44
|
+
fi
|
|
45
|
+
|
|
46
|
+
exit 0
|
|
47
|
+
`;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Generate a pre-push hook script.
|
|
52
|
+
* Runs full analysis including LLM-powered review.
|
|
53
|
+
*
|
|
54
|
+
* @returns {string} Shell script content
|
|
55
|
+
*/
|
|
56
|
+
function generatePrePushHook() {
|
|
57
|
+
return `#!/bin/sh
|
|
58
|
+
${TLC_HOOK_MARKER} — pre-push
|
|
59
|
+
# Runs full code gate including LLM review before push.
|
|
60
|
+
# To bypass: git push --no-verify (bypass is logged)
|
|
61
|
+
|
|
62
|
+
PROJECT_ROOT="$(git rev-parse --show-toplevel)"
|
|
63
|
+
|
|
64
|
+
if command -v node > /dev/null 2>&1; then
|
|
65
|
+
node "$PROJECT_ROOT/node_modules/.bin/tlc-gate" check --hook pre-push --full
|
|
66
|
+
EXIT_CODE=$?
|
|
67
|
+
|
|
68
|
+
if [ $EXIT_CODE -ne 0 ]; then
|
|
69
|
+
echo ""
|
|
70
|
+
echo "Push blocked by TLC Code Gate."
|
|
71
|
+
echo "Fix the issues above or use: git push --no-verify"
|
|
72
|
+
exit 1
|
|
73
|
+
fi
|
|
74
|
+
else
|
|
75
|
+
echo "Warning: Node.js not found. Skipping TLC Code Gate."
|
|
76
|
+
fi
|
|
77
|
+
|
|
78
|
+
exit 0
|
|
79
|
+
`;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Install git hooks into the project's .git/hooks/ directory.
|
|
84
|
+
*
|
|
85
|
+
* @param {string} projectPath - Path to project root
|
|
86
|
+
* @param {Object} [options] - Options
|
|
87
|
+
* @param {Object} [options.fs] - File system module (for testing)
|
|
88
|
+
* @param {string[]} [options.hooks] - Which hooks to install (default: both)
|
|
89
|
+
* @returns {Promise<{installed: string[]}>}
|
|
90
|
+
*/
|
|
91
|
+
async function installHooks(projectPath, options = {}) {
|
|
92
|
+
const fsModule = options.fs || fs;
|
|
93
|
+
const hooks = options.hooks || ['pre-commit', 'pre-push'];
|
|
94
|
+
const gitDir = path.join(projectPath, '.git');
|
|
95
|
+
|
|
96
|
+
if (!fsModule.existsSync(gitDir)) {
|
|
97
|
+
throw new Error('Not a git repository: .git directory not found');
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
const hooksDir = path.join(gitDir, 'hooks');
|
|
101
|
+
const installed = [];
|
|
102
|
+
|
|
103
|
+
const generators = {
|
|
104
|
+
'pre-commit': generatePreCommitHook,
|
|
105
|
+
'pre-push': generatePrePushHook,
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
for (const hookName of hooks) {
|
|
109
|
+
const generator = generators[hookName];
|
|
110
|
+
if (!generator) continue;
|
|
111
|
+
|
|
112
|
+
const hookPath = path.join(hooksDir, hookName);
|
|
113
|
+
const content = generator();
|
|
114
|
+
|
|
115
|
+
fsModule.writeFileSync(hookPath, content, 'utf-8');
|
|
116
|
+
fsModule.chmodSync(hookPath, '755');
|
|
117
|
+
installed.push(hookName);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
return { installed };
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* Check if a TLC code gate hook is installed.
|
|
125
|
+
*
|
|
126
|
+
* @param {string} projectPath
|
|
127
|
+
* @param {string} hookName - Hook name (pre-commit, pre-push)
|
|
128
|
+
* @param {Object} [options]
|
|
129
|
+
* @param {Object} [options.fs] - File system module
|
|
130
|
+
* @returns {boolean}
|
|
131
|
+
*/
|
|
132
|
+
function isHookInstalled(projectPath, hookName, options = {}) {
|
|
133
|
+
const fsModule = options.fs || fs;
|
|
134
|
+
const hookPath = path.join(projectPath, '.git', 'hooks', hookName);
|
|
135
|
+
|
|
136
|
+
if (!fsModule.existsSync(hookPath)) {
|
|
137
|
+
return false;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
const content = fsModule.readFileSync(hookPath, 'utf-8');
|
|
141
|
+
return content.includes(TLC_HOOK_MARKER);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
module.exports = {
|
|
145
|
+
generatePreCommitHook,
|
|
146
|
+
generatePrePushHook,
|
|
147
|
+
installHooks,
|
|
148
|
+
isHookInstalled,
|
|
149
|
+
};
|