@amsterdamdatalabs/enact-factory 0.1.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 +674 -0
- package/README.md +566 -0
- package/dist/adapters/agenticLoop.d.ts +90 -0
- package/dist/adapters/agenticLoop.d.ts.map +1 -0
- package/dist/adapters/agenticLoop.js +219 -0
- package/dist/adapters/agenticLoop.js.map +1 -0
- package/dist/adapters/base.d.ts +16 -0
- package/dist/adapters/base.d.ts.map +1 -0
- package/dist/adapters/base.js +135 -0
- package/dist/adapters/base.js.map +1 -0
- package/dist/adapters/claude.d.ts +13 -0
- package/dist/adapters/claude.d.ts.map +1 -0
- package/dist/adapters/claude.js +318 -0
- package/dist/adapters/claude.js.map +1 -0
- package/dist/adapters/codex.d.ts +14 -0
- package/dist/adapters/codex.d.ts.map +1 -0
- package/dist/adapters/codex.js +366 -0
- package/dist/adapters/codex.js.map +1 -0
- package/dist/adapters/cryptoQuantAdapter.d.ts +85 -0
- package/dist/adapters/cryptoQuantAdapter.d.ts.map +1 -0
- package/dist/adapters/cryptoQuantAdapter.js +238 -0
- package/dist/adapters/cryptoQuantAdapter.js.map +1 -0
- package/dist/adapters/cursor.d.ts +13 -0
- package/dist/adapters/cursor.d.ts.map +1 -0
- package/dist/adapters/cursor.js +300 -0
- package/dist/adapters/cursor.js.map +1 -0
- package/dist/adapters/envPath.d.ts +20 -0
- package/dist/adapters/envPath.d.ts.map +1 -0
- package/dist/adapters/envPath.js +49 -0
- package/dist/adapters/envPath.js.map +1 -0
- package/dist/adapters/hermes.d.ts +13 -0
- package/dist/adapters/hermes.d.ts.map +1 -0
- package/dist/adapters/hermes.js +283 -0
- package/dist/adapters/hermes.js.map +1 -0
- package/dist/adapters/index.d.ts +18 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +56 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/opencode.d.ts +13 -0
- package/dist/adapters/opencode.d.ts.map +1 -0
- package/dist/adapters/opencode.js +282 -0
- package/dist/adapters/opencode.js.map +1 -0
- package/dist/adapters/processRegistry.d.ts +38 -0
- package/dist/adapters/processRegistry.d.ts.map +1 -0
- package/dist/adapters/processRegistry.js +147 -0
- package/dist/adapters/processRegistry.js.map +1 -0
- package/dist/adapters/responses.d.ts +16 -0
- package/dist/adapters/responses.d.ts.map +1 -0
- package/dist/adapters/responses.js +244 -0
- package/dist/adapters/responses.js.map +1 -0
- package/dist/adapters/streamBuffer.d.ts +59 -0
- package/dist/adapters/streamBuffer.d.ts.map +1 -0
- package/dist/adapters/streamBuffer.js +123 -0
- package/dist/adapters/streamBuffer.js.map +1 -0
- package/dist/adapters/tools.d.ts +30 -0
- package/dist/adapters/tools.d.ts.map +1 -0
- package/dist/adapters/tools.js +219 -0
- package/dist/adapters/tools.js.map +1 -0
- package/dist/adapters/types.d.ts +82 -0
- package/dist/adapters/types.d.ts.map +1 -0
- package/dist/adapters/types.js +6 -0
- package/dist/adapters/types.js.map +1 -0
- package/dist/agents/agentBus.d.ts +160 -0
- package/dist/agents/agentBus.d.ts.map +1 -0
- package/dist/agents/agentBus.js +350 -0
- package/dist/agents/agentBus.js.map +1 -0
- package/dist/agents/agentPair.d.ts +215 -0
- package/dist/agents/agentPair.d.ts.map +1 -0
- package/dist/agents/agentPair.js +456 -0
- package/dist/agents/agentPair.js.map +1 -0
- package/dist/agents/auditor.d.ts +27 -0
- package/dist/agents/auditor.d.ts.map +1 -0
- package/dist/agents/auditor.js +238 -0
- package/dist/agents/auditor.js.map +1 -0
- package/dist/agents/cliStreamParser.d.ts +18 -0
- package/dist/agents/cliStreamParser.d.ts.map +1 -0
- package/dist/agents/cliStreamParser.js +156 -0
- package/dist/agents/cliStreamParser.js.map +1 -0
- package/dist/agents/documenter.d.ts +31 -0
- package/dist/agents/documenter.d.ts.map +1 -0
- package/dist/agents/documenter.js +286 -0
- package/dist/agents/documenter.js.map +1 -0
- package/dist/agents/draftAnalyzer.d.ts +50 -0
- package/dist/agents/draftAnalyzer.d.ts.map +1 -0
- package/dist/agents/draftAnalyzer.js +289 -0
- package/dist/agents/draftAnalyzer.js.map +1 -0
- package/dist/agents/evaluator.d.ts +61 -0
- package/dist/agents/evaluator.d.ts.map +1 -0
- package/dist/agents/evaluator.js +338 -0
- package/dist/agents/evaluator.js.map +1 -0
- package/dist/agents/executor.d.ts +33 -0
- package/dist/agents/executor.d.ts.map +1 -0
- package/dist/agents/executor.js +130 -0
- package/dist/agents/executor.js.map +1 -0
- package/dist/agents/index.d.ts +10 -0
- package/dist/agents/index.d.ts.map +1 -0
- package/dist/agents/index.js +10 -0
- package/dist/agents/index.js.map +1 -0
- package/dist/agents/pairMetrics.d.ts +63 -0
- package/dist/agents/pairMetrics.d.ts.map +1 -0
- package/dist/agents/pairMetrics.js +232 -0
- package/dist/agents/pairMetrics.js.map +1 -0
- package/dist/agents/pairPipeline.d.ts +184 -0
- package/dist/agents/pairPipeline.d.ts.map +1 -0
- package/dist/agents/pairPipeline.js +934 -0
- package/dist/agents/pairPipeline.js.map +1 -0
- package/dist/agents/pairWebhook.d.ts +59 -0
- package/dist/agents/pairWebhook.d.ts.map +1 -0
- package/dist/agents/pairWebhook.js +242 -0
- package/dist/agents/pairWebhook.js.map +1 -0
- package/dist/agents/pipelineFormat.d.ts +8 -0
- package/dist/agents/pipelineFormat.d.ts.map +1 -0
- package/dist/agents/pipelineFormat.js +65 -0
- package/dist/agents/pipelineFormat.js.map +1 -0
- package/dist/agents/pipelineGuards.d.ts +23 -0
- package/dist/agents/pipelineGuards.d.ts.map +1 -0
- package/dist/agents/pipelineGuards.js +257 -0
- package/dist/agents/pipelineGuards.js.map +1 -0
- package/dist/agents/reviewer.d.ts +37 -0
- package/dist/agents/reviewer.d.ts.map +1 -0
- package/dist/agents/reviewer.js +214 -0
- package/dist/agents/reviewer.js.map +1 -0
- package/dist/agents/skillDocumenter.d.ts +23 -0
- package/dist/agents/skillDocumenter.d.ts.map +1 -0
- package/dist/agents/skillDocumenter.js +219 -0
- package/dist/agents/skillDocumenter.js.map +1 -0
- package/dist/agents/tester.d.ts +37 -0
- package/dist/agents/tester.d.ts.map +1 -0
- package/dist/agents/tester.js +309 -0
- package/dist/agents/tester.js.map +1 -0
- package/dist/automation/autonomousRunner.d.ts +145 -0
- package/dist/automation/autonomousRunner.d.ts.map +1 -0
- package/dist/automation/autonomousRunner.js +1272 -0
- package/dist/automation/autonomousRunner.js.map +1 -0
- package/dist/automation/dailyReporter.d.ts +26 -0
- package/dist/automation/dailyReporter.d.ts.map +1 -0
- package/dist/automation/dailyReporter.js +130 -0
- package/dist/automation/dailyReporter.js.map +1 -0
- package/dist/automation/index.d.ts +5 -0
- package/dist/automation/index.d.ts.map +1 -0
- package/dist/automation/index.js +5 -0
- package/dist/automation/index.js.map +1 -0
- package/dist/automation/longRunningMonitor.d.ts +26 -0
- package/dist/automation/longRunningMonitor.d.ts.map +1 -0
- package/dist/automation/longRunningMonitor.js +356 -0
- package/dist/automation/longRunningMonitor.js.map +1 -0
- package/dist/automation/prOwnership.d.ts +18 -0
- package/dist/automation/prOwnership.d.ts.map +1 -0
- package/dist/automation/prOwnership.js +61 -0
- package/dist/automation/prOwnership.js.map +1 -0
- package/dist/automation/runnerExecution.d.ts +57 -0
- package/dist/automation/runnerExecution.d.ts.map +1 -0
- package/dist/automation/runnerExecution.js +701 -0
- package/dist/automation/runnerExecution.js.map +1 -0
- package/dist/automation/runnerState.d.ts +170 -0
- package/dist/automation/runnerState.d.ts.map +1 -0
- package/dist/automation/runnerState.js +496 -0
- package/dist/automation/runnerState.js.map +1 -0
- package/dist/automation/runnerTypes.d.ts +57 -0
- package/dist/automation/runnerTypes.d.ts.map +1 -0
- package/dist/automation/runnerTypes.js +5 -0
- package/dist/automation/runnerTypes.js.map +1 -0
- package/dist/automation/scheduler.d.ts +75 -0
- package/dist/automation/scheduler.d.ts.map +1 -0
- package/dist/automation/scheduler.js +402 -0
- package/dist/automation/scheduler.js.map +1 -0
- package/dist/azdo/azdo.d.ts +70 -0
- package/dist/azdo/azdo.d.ts.map +1 -0
- package/dist/azdo/azdo.js +328 -0
- package/dist/azdo/azdo.js.map +1 -0
- package/dist/azdo/index.d.ts +3 -0
- package/dist/azdo/index.d.ts.map +1 -0
- package/dist/azdo/index.js +3 -0
- package/dist/azdo/index.js.map +1 -0
- package/dist/azdo/projectUpdater.d.ts +13 -0
- package/dist/azdo/projectUpdater.d.ts.map +1 -0
- package/dist/azdo/projectUpdater.js +155 -0
- package/dist/azdo/projectUpdater.js.map +1 -0
- package/dist/azureDevOps/client.d.ts +75 -0
- package/dist/azureDevOps/client.d.ts.map +1 -0
- package/dist/azureDevOps/client.js +150 -0
- package/dist/azureDevOps/client.js.map +1 -0
- package/dist/azureDevOps/hierarchy.d.ts +119 -0
- package/dist/azureDevOps/hierarchy.d.ts.map +1 -0
- package/dist/azureDevOps/hierarchy.js +470 -0
- package/dist/azureDevOps/hierarchy.js.map +1 -0
- package/dist/azureDevOps/mapper.d.ts +101 -0
- package/dist/azureDevOps/mapper.d.ts.map +1 -0
- package/dist/azureDevOps/mapper.js +438 -0
- package/dist/azureDevOps/mapper.js.map +1 -0
- package/dist/azureDevOps/stateMapping.d.ts +15 -0
- package/dist/azureDevOps/stateMapping.d.ts.map +1 -0
- package/dist/azureDevOps/stateMapping.js +141 -0
- package/dist/azureDevOps/stateMapping.js.map +1 -0
- package/dist/cli/authHandler.d.ts +13 -0
- package/dist/cli/authHandler.d.ts.map +1 -0
- package/dist/cli/authHandler.js +70 -0
- package/dist/cli/authHandler.js.map +1 -0
- package/dist/cli/checkHandler.d.ts +27 -0
- package/dist/cli/checkHandler.d.ts.map +1 -0
- package/dist/cli/checkHandler.js +560 -0
- package/dist/cli/checkHandler.js.map +1 -0
- package/dist/cli/daemon.d.ts +30 -0
- package/dist/cli/daemon.d.ts.map +1 -0
- package/dist/cli/daemon.js +141 -0
- package/dist/cli/daemon.js.map +1 -0
- package/dist/cli/factoryCommands.d.ts +3 -0
- package/dist/cli/factoryCommands.d.ts.map +1 -0
- package/dist/cli/factoryCommands.js +165 -0
- package/dist/cli/factoryCommands.js.map +1 -0
- package/dist/cli/promptHandler.d.ts +13 -0
- package/dist/cli/promptHandler.d.ts.map +1 -0
- package/dist/cli/promptHandler.js +193 -0
- package/dist/cli/promptHandler.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +320 -0
- package/dist/cli.js.map +1 -0
- package/dist/core/agentLifecycle.d.ts +322 -0
- package/dist/core/agentLifecycle.d.ts.map +1 -0
- package/dist/core/agentLifecycle.js +230 -0
- package/dist/core/agentLifecycle.js.map +1 -0
- package/dist/core/areaMapping.d.ts +9 -0
- package/dist/core/areaMapping.d.ts.map +1 -0
- package/dist/core/areaMapping.js +37 -0
- package/dist/core/areaMapping.js.map +1 -0
- package/dist/core/config.d.ts +469 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +780 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/dashboardContract.d.ts +204 -0
- package/dist/core/dashboardContract.d.ts.map +1 -0
- package/dist/core/dashboardContract.js +205 -0
- package/dist/core/dashboardContract.js.map +1 -0
- package/dist/core/devopsModel.d.ts +138 -0
- package/dist/core/devopsModel.d.ts.map +1 -0
- package/dist/core/devopsModel.js +137 -0
- package/dist/core/devopsModel.js.map +1 -0
- package/dist/core/envFile.d.ts +11 -0
- package/dist/core/envFile.d.ts.map +1 -0
- package/dist/core/envFile.js +104 -0
- package/dist/core/envFile.js.map +1 -0
- package/dist/core/eventHub.d.ts +220 -0
- package/dist/core/eventHub.d.ts.map +1 -0
- package/dist/core/eventHub.js +136 -0
- package/dist/core/eventHub.js.map +1 -0
- package/dist/core/index.d.ts +8 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +7 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/laneExecutionState.d.ts +29 -0
- package/dist/core/laneExecutionState.d.ts.map +1 -0
- package/dist/core/laneExecutionState.js +18 -0
- package/dist/core/laneExecutionState.js.map +1 -0
- package/dist/core/laneStatus.d.ts +49 -0
- package/dist/core/laneStatus.d.ts.map +1 -0
- package/dist/core/laneStatus.js +153 -0
- package/dist/core/laneStatus.js.map +1 -0
- package/dist/core/prSidecar.d.ts +96 -0
- package/dist/core/prSidecar.d.ts.map +1 -0
- package/dist/core/prSidecar.js +33 -0
- package/dist/core/prSidecar.js.map +1 -0
- package/dist/core/runtimeConfig.d.ts +6 -0
- package/dist/core/runtimeConfig.d.ts.map +1 -0
- package/dist/core/runtimeConfig.js +24 -0
- package/dist/core/runtimeConfig.js.map +1 -0
- package/dist/core/scmProvider.d.ts +19 -0
- package/dist/core/scmProvider.d.ts.map +1 -0
- package/dist/core/scmProvider.js +38 -0
- package/dist/core/scmProvider.js.map +1 -0
- package/dist/core/service.d.ts +10 -0
- package/dist/core/service.d.ts.map +1 -0
- package/dist/core/service.js +297 -0
- package/dist/core/service.js.map +1 -0
- package/dist/core/traceCollector.d.ts +105 -0
- package/dist/core/traceCollector.d.ts.map +1 -0
- package/dist/core/traceCollector.js +141 -0
- package/dist/core/traceCollector.js.map +1 -0
- package/dist/core/types.d.ts +432 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +2 -0
- package/dist/core/types.js.map +1 -0
- package/dist/core/workItemMapper.d.ts +39 -0
- package/dist/core/workItemMapper.d.ts.map +1 -0
- package/dist/core/workItemMapper.js +427 -0
- package/dist/core/workItemMapper.js.map +1 -0
- package/dist/core/workItemModel.d.ts +120 -0
- package/dist/core/workItemModel.d.ts.map +1 -0
- package/dist/core/workItemModel.js +104 -0
- package/dist/core/workItemModel.js.map +1 -0
- package/dist/core/workItemPayload.d.ts +195 -0
- package/dist/core/workItemPayload.d.ts.map +1 -0
- package/dist/core/workItemPayload.js +24 -0
- package/dist/core/workItemPayload.js.map +1 -0
- package/dist/core/workspaceConfig.d.ts +57 -0
- package/dist/core/workspaceConfig.d.ts.map +1 -0
- package/dist/core/workspaceConfig.js +184 -0
- package/dist/core/workspaceConfig.js.map +1 -0
- package/dist/doctor.d.ts +18 -0
- package/dist/doctor.d.ts.map +1 -0
- package/dist/doctor.js +34 -0
- package/dist/doctor.js.map +1 -0
- package/dist/factory/activeSkill.d.ts +11 -0
- package/dist/factory/activeSkill.d.ts.map +1 -0
- package/dist/factory/activeSkill.js +44 -0
- package/dist/factory/activeSkill.js.map +1 -0
- package/dist/factory/assignment.d.ts +54 -0
- package/dist/factory/assignment.d.ts.map +1 -0
- package/dist/factory/assignment.js +94 -0
- package/dist/factory/assignment.js.map +1 -0
- package/dist/factory/auditLog.d.ts +10 -0
- package/dist/factory/auditLog.d.ts.map +1 -0
- package/dist/factory/auditLog.js +38 -0
- package/dist/factory/auditLog.js.map +1 -0
- package/dist/factory/closureRequirements.d.ts +12 -0
- package/dist/factory/closureRequirements.d.ts.map +1 -0
- package/dist/factory/closureRequirements.js +30 -0
- package/dist/factory/closureRequirements.js.map +1 -0
- package/dist/factory/delegationPrompt.d.ts +3 -0
- package/dist/factory/delegationPrompt.d.ts.map +1 -0
- package/dist/factory/delegationPrompt.js +16 -0
- package/dist/factory/delegationPrompt.js.map +1 -0
- package/dist/factory/http.d.ts +3 -0
- package/dist/factory/http.d.ts.map +1 -0
- package/dist/factory/http.js +555 -0
- package/dist/factory/http.js.map +1 -0
- package/dist/factory/lifecyclePushMap.d.ts +4 -0
- package/dist/factory/lifecyclePushMap.d.ts.map +1 -0
- package/dist/factory/lifecyclePushMap.js +7 -0
- package/dist/factory/lifecyclePushMap.js.map +1 -0
- package/dist/factory/missions.d.ts +125 -0
- package/dist/factory/missions.d.ts.map +1 -0
- package/dist/factory/missions.js +304 -0
- package/dist/factory/missions.js.map +1 -0
- package/dist/factory/mode.d.ts +9 -0
- package/dist/factory/mode.d.ts.map +1 -0
- package/dist/factory/mode.js +30 -0
- package/dist/factory/mode.js.map +1 -0
- package/dist/factory/operatorActiveSkill.d.ts +15 -0
- package/dist/factory/operatorActiveSkill.d.ts.map +1 -0
- package/dist/factory/operatorActiveSkill.js +95 -0
- package/dist/factory/operatorActiveSkill.js.map +1 -0
- package/dist/factory/paseoDispatcher.d.ts +52 -0
- package/dist/factory/paseoDispatcher.d.ts.map +1 -0
- package/dist/factory/paseoDispatcher.js +122 -0
- package/dist/factory/paseoDispatcher.js.map +1 -0
- package/dist/factory/paseoLifecycle.d.ts +32 -0
- package/dist/factory/paseoLifecycle.d.ts.map +1 -0
- package/dist/factory/paseoLifecycle.js +260 -0
- package/dist/factory/paseoLifecycle.js.map +1 -0
- package/dist/factory/paths.d.ts +31 -0
- package/dist/factory/paths.d.ts.map +1 -0
- package/dist/factory/paths.js +139 -0
- package/dist/factory/paths.js.map +1 -0
- package/dist/factory/progressWatchdog.d.ts +58 -0
- package/dist/factory/progressWatchdog.d.ts.map +1 -0
- package/dist/factory/progressWatchdog.js +160 -0
- package/dist/factory/progressWatchdog.js.map +1 -0
- package/dist/factory/roster.d.ts +59 -0
- package/dist/factory/roster.d.ts.map +1 -0
- package/dist/factory/roster.js +116 -0
- package/dist/factory/roster.js.map +1 -0
- package/dist/factory/runtime.d.ts +44 -0
- package/dist/factory/runtime.d.ts.map +1 -0
- package/dist/factory/runtime.js +238 -0
- package/dist/factory/runtime.js.map +1 -0
- package/dist/factory/sync.d.ts +29 -0
- package/dist/factory/sync.d.ts.map +1 -0
- package/dist/factory/sync.js +77 -0
- package/dist/factory/sync.js.map +1 -0
- package/dist/factory/workitemQueues.d.ts +37 -0
- package/dist/factory/workitemQueues.d.ts.map +1 -0
- package/dist/factory/workitemQueues.js +99 -0
- package/dist/factory/workitemQueues.js.map +1 -0
- package/dist/factory/workitemTriage.d.ts +9 -0
- package/dist/factory/workitemTriage.d.ts.map +1 -0
- package/dist/factory/workitemTriage.js +81 -0
- package/dist/factory/workitemTriage.js.map +1 -0
- package/dist/hooks.d.ts +18 -0
- package/dist/hooks.d.ts.map +1 -0
- package/dist/hooks.js +96 -0
- package/dist/hooks.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +90 -0
- package/dist/index.js.map +1 -0
- package/dist/install/agentCatalog.d.ts +7 -0
- package/dist/install/agentCatalog.d.ts.map +1 -0
- package/dist/install/agentCatalog.js +28 -0
- package/dist/install/agentCatalog.js.map +1 -0
- package/dist/install/bundlePaths.d.ts +10 -0
- package/dist/install/bundlePaths.d.ts.map +1 -0
- package/dist/install/bundlePaths.js +30 -0
- package/dist/install/bundlePaths.js.map +1 -0
- package/dist/install/codex.d.ts +43 -0
- package/dist/install/codex.d.ts.map +1 -0
- package/dist/install/codex.js +207 -0
- package/dist/install/codex.js.map +1 -0
- package/dist/install/enactHome.d.ts +37 -0
- package/dist/install/enactHome.d.ts.map +1 -0
- package/dist/install/enactHome.js +152 -0
- package/dist/install/enactHome.js.map +1 -0
- package/dist/install/plugins.d.ts +115 -0
- package/dist/install/plugins.d.ts.map +1 -0
- package/dist/install/plugins.js +259 -0
- package/dist/install/plugins.js.map +1 -0
- package/dist/install/setup.d.ts +33 -0
- package/dist/install/setup.d.ts.map +1 -0
- package/dist/install/setup.js +167 -0
- package/dist/install/setup.js.map +1 -0
- package/dist/locale/en.d.ts +3 -0
- package/dist/locale/en.d.ts.map +1 -0
- package/dist/locale/en.js +435 -0
- package/dist/locale/en.js.map +1 -0
- package/dist/locale/index.d.ts +28 -0
- package/dist/locale/index.d.ts.map +1 -0
- package/dist/locale/index.js +84 -0
- package/dist/locale/index.js.map +1 -0
- package/dist/locale/prompts/en.d.ts +3 -0
- package/dist/locale/prompts/en.d.ts.map +1 -0
- package/dist/locale/prompts/en.js +254 -0
- package/dist/locale/prompts/en.js.map +1 -0
- package/dist/locale/types.d.ts +433 -0
- package/dist/locale/types.d.ts.map +1 -0
- package/dist/locale/types.js +5 -0
- package/dist/locale/types.js.map +1 -0
- package/dist/mcp/server.d.ts +489 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +597 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/orchestration/decisionEngine.d.ts +175 -0
- package/dist/orchestration/decisionEngine.d.ts.map +1 -0
- package/dist/orchestration/decisionEngine.js +471 -0
- package/dist/orchestration/decisionEngine.js.map +1 -0
- package/dist/orchestration/index.d.ts +5 -0
- package/dist/orchestration/index.d.ts.map +1 -0
- package/dist/orchestration/index.js +5 -0
- package/dist/orchestration/index.js.map +1 -0
- package/dist/orchestration/workItemParser.d.ts +67 -0
- package/dist/orchestration/workItemParser.d.ts.map +1 -0
- package/dist/orchestration/workItemParser.js +560 -0
- package/dist/orchestration/workItemParser.js.map +1 -0
- package/dist/orchestration/workItemScheduler.d.ts +141 -0
- package/dist/orchestration/workItemScheduler.d.ts.map +1 -0
- package/dist/orchestration/workItemScheduler.js +317 -0
- package/dist/orchestration/workItemScheduler.js.map +1 -0
- package/dist/orchestration/workflow.d.ts +145 -0
- package/dist/orchestration/workflow.d.ts.map +1 -0
- package/dist/orchestration/workflow.js +301 -0
- package/dist/orchestration/workflow.js.map +1 -0
- package/dist/providers/codexSessions.d.ts +93 -0
- package/dist/providers/codexSessions.d.ts.map +1 -0
- package/dist/providers/codexSessions.js +366 -0
- package/dist/providers/codexSessions.js.map +1 -0
- package/dist/registry/bsDetector.d.ts +24 -0
- package/dist/registry/bsDetector.d.ts.map +1 -0
- package/dist/registry/bsDetector.js +276 -0
- package/dist/registry/bsDetector.js.map +1 -0
- package/dist/registry/entityScanner.d.ts +36 -0
- package/dist/registry/entityScanner.d.ts.map +1 -0
- package/dist/registry/entityScanner.js +693 -0
- package/dist/registry/entityScanner.js.map +1 -0
- package/dist/registry/index.d.ts +9 -0
- package/dist/registry/index.d.ts.map +1 -0
- package/dist/registry/index.js +13 -0
- package/dist/registry/index.js.map +1 -0
- package/dist/registry/schema.d.ts +307 -0
- package/dist/registry/schema.d.ts.map +1 -0
- package/dist/registry/schema.js +139 -0
- package/dist/registry/schema.js.map +1 -0
- package/dist/registry/sqliteStore.d.ts +101 -0
- package/dist/registry/sqliteStore.d.ts.map +1 -0
- package/dist/registry/sqliteStore.js +688 -0
- package/dist/registry/sqliteStore.js.map +1 -0
- package/dist/registry/workItemBridge.d.ts +8 -0
- package/dist/registry/workItemBridge.d.ts.map +1 -0
- package/dist/registry/workItemBridge.js +30 -0
- package/dist/registry/workItemBridge.js.map +1 -0
- package/dist/runners/cliRunner.d.ts +11 -0
- package/dist/runners/cliRunner.d.ts.map +1 -0
- package/dist/runners/cliRunner.js +193 -0
- package/dist/runners/cliRunner.js.map +1 -0
- package/dist/support/apiCache.d.ts +85 -0
- package/dist/support/apiCache.d.ts.map +1 -0
- package/dist/support/apiCache.js +163 -0
- package/dist/support/apiCache.js.map +1 -0
- package/dist/support/chat.d.ts +3 -0
- package/dist/support/chat.d.ts.map +1 -0
- package/dist/support/chat.js +305 -0
- package/dist/support/chat.js.map +1 -0
- package/dist/support/chatBackend.d.ts +25 -0
- package/dist/support/chatBackend.d.ts.map +1 -0
- package/dist/support/chatBackend.js +289 -0
- package/dist/support/chatBackend.js.map +1 -0
- package/dist/support/chatTui.d.ts +3 -0
- package/dist/support/chatTui.d.ts.map +1 -0
- package/dist/support/chatTui.js +1082 -0
- package/dist/support/chatTui.js.map +1 -0
- package/dist/support/costTracker.d.ts +29 -0
- package/dist/support/costTracker.d.ts.map +1 -0
- package/dist/support/costTracker.js +113 -0
- package/dist/support/costTracker.js.map +1 -0
- package/dist/support/dashboardHtml.d.ts +5 -0
- package/dist/support/dashboardHtml.d.ts.map +1 -0
- package/dist/support/dashboardHtml.js +2629 -0
- package/dist/support/dashboardHtml.js.map +1 -0
- package/dist/support/dev.d.ts +55 -0
- package/dist/support/dev.d.ts.map +1 -0
- package/dist/support/dev.js +298 -0
- package/dist/support/dev.js.map +1 -0
- package/dist/support/editParser.d.ts +37 -0
- package/dist/support/editParser.d.ts.map +1 -0
- package/dist/support/editParser.js +365 -0
- package/dist/support/editParser.js.map +1 -0
- package/dist/support/ghosttyThemeCatalog.generated.d.ts +2 -0
- package/dist/support/ghosttyThemeCatalog.generated.d.ts.map +1 -0
- package/dist/support/ghosttyThemeCatalog.generated.js +11116 -0
- package/dist/support/ghosttyThemeCatalog.generated.js.map +1 -0
- package/dist/support/gitStatus.d.ts +21 -0
- package/dist/support/gitStatus.d.ts.map +1 -0
- package/dist/support/gitStatus.js +108 -0
- package/dist/support/gitStatus.js.map +1 -0
- package/dist/support/gitTracker.d.ts +30 -0
- package/dist/support/gitTracker.d.ts.map +1 -0
- package/dist/support/gitTracker.js +143 -0
- package/dist/support/gitTracker.js.map +1 -0
- package/dist/support/index.d.ts +12 -0
- package/dist/support/index.d.ts.map +1 -0
- package/dist/support/index.js +12 -0
- package/dist/support/index.js.map +1 -0
- package/dist/support/planner.d.ts +64 -0
- package/dist/support/planner.d.ts.map +1 -0
- package/dist/support/planner.js +396 -0
- package/dist/support/planner.js.map +1 -0
- package/dist/support/projectMapper.d.ts +46 -0
- package/dist/support/projectMapper.d.ts.map +1 -0
- package/dist/support/projectMapper.js +273 -0
- package/dist/support/projectMapper.js.map +1 -0
- package/dist/support/pty-helper.py +117 -0
- package/dist/support/quotaTracker.d.ts +29 -0
- package/dist/support/quotaTracker.d.ts.map +1 -0
- package/dist/support/quotaTracker.js +89 -0
- package/dist/support/quotaTracker.js.map +1 -0
- package/dist/support/rateLimiter.d.ts +101 -0
- package/dist/support/rateLimiter.d.ts.map +1 -0
- package/dist/support/rateLimiter.js +219 -0
- package/dist/support/rateLimiter.js.map +1 -0
- package/dist/support/rollback.d.ts +61 -0
- package/dist/support/rollback.d.ts.map +1 -0
- package/dist/support/rollback.js +329 -0
- package/dist/support/rollback.js.map +1 -0
- package/dist/support/sharedShell.d.ts +17 -0
- package/dist/support/sharedShell.d.ts.map +1 -0
- package/dist/support/sharedShell.js +439 -0
- package/dist/support/sharedShell.js.map +1 -0
- package/dist/support/stuckDetector.d.ts +68 -0
- package/dist/support/stuckDetector.d.ts.map +1 -0
- package/dist/support/stuckDetector.js +174 -0
- package/dist/support/stuckDetector.js.map +1 -0
- package/dist/support/terminalBridge.d.ts +18 -0
- package/dist/support/terminalBridge.d.ts.map +1 -0
- package/dist/support/terminalBridge.js +553 -0
- package/dist/support/terminalBridge.js.map +1 -0
- package/dist/support/timeWindow.d.ts +60 -0
- package/dist/support/timeWindow.d.ts.map +1 -0
- package/dist/support/timeWindow.js +236 -0
- package/dist/support/timeWindow.js.map +1 -0
- package/dist/support/uiThemes.d.ts +44 -0
- package/dist/support/uiThemes.d.ts.map +1 -0
- package/dist/support/uiThemes.js +290 -0
- package/dist/support/uiThemes.js.map +1 -0
- package/dist/support/web.d.ts +29 -0
- package/dist/support/web.d.ts.map +1 -0
- package/dist/support/web.js +1097 -0
- package/dist/support/web.js.map +1 -0
- package/dist/support/worktreeManager.d.ts +20 -0
- package/dist/support/worktreeManager.d.ts.map +1 -0
- package/dist/support/worktreeManager.js +140 -0
- package/dist/support/worktreeManager.js.map +1 -0
- package/dist/task_state_model.py +55 -0
- package/dist/workItemState/store.d.ts +122 -0
- package/dist/workItemState/store.d.ts.map +1 -0
- package/dist/workItemState/store.js +438 -0
- package/dist/workItemState/store.js.map +1 -0
- package/dist/workItems/azdoBridge.d.ts +42 -0
- package/dist/workItems/azdoBridge.d.ts.map +1 -0
- package/dist/workItems/azdoBridge.js +143 -0
- package/dist/workItems/azdoBridge.js.map +1 -0
- package/dist/workItems/azdoSyncRuntime.d.ts +28 -0
- package/dist/workItems/azdoSyncRuntime.d.ts.map +1 -0
- package/dist/workItems/azdoSyncRuntime.js +158 -0
- package/dist/workItems/azdoSyncRuntime.js.map +1 -0
- package/dist/workItems/azureDevOpsSync.d.ts +128 -0
- package/dist/workItems/azureDevOpsSync.d.ts.map +1 -0
- package/dist/workItems/azureDevOpsSync.js +748 -0
- package/dist/workItems/azureDevOpsSync.js.map +1 -0
- package/dist/workItems/helpers.d.ts +11 -0
- package/dist/workItems/helpers.d.ts.map +1 -0
- package/dist/workItems/helpers.js +17 -0
- package/dist/workItems/helpers.js.map +1 -0
- package/dist/workItems/index.d.ts +21 -0
- package/dist/workItems/index.d.ts.map +1 -0
- package/dist/workItems/index.js +89 -0
- package/dist/workItems/index.js.map +1 -0
- package/dist/workItems/localWorkItemFetcher.d.ts +55 -0
- package/dist/workItems/localWorkItemFetcher.d.ts.map +1 -0
- package/dist/workItems/localWorkItemFetcher.js +209 -0
- package/dist/workItems/localWorkItemFetcher.js.map +1 -0
- package/dist/workItems/migrations/001_rename_workItem_to_work_item.sql +10 -0
- package/dist/workItems/postgresStore.d.ts +78 -0
- package/dist/workItems/postgresStore.d.ts.map +1 -0
- package/dist/workItems/postgresStore.js +937 -0
- package/dist/workItems/postgresStore.js.map +1 -0
- package/dist/workItems/schema.d.ts +257 -0
- package/dist/workItems/schema.d.ts.map +1 -0
- package/dist/workItems/schema.js +176 -0
- package/dist/workItems/schema.js.map +1 -0
- package/dist/workItems/sqliteStore.d.ts +124 -0
- package/dist/workItems/sqliteStore.d.ts.map +1 -0
- package/dist/workItems/sqliteStore.js +713 -0
- package/dist/workItems/sqliteStore.js.map +1 -0
- package/dist/workItems/workItemBoardHtml.d.ts +5 -0
- package/dist/workItems/workItemBoardHtml.d.ts.map +1 -0
- package/dist/workItems/workItemBoardHtml.js +2192 -0
- package/dist/workItems/workItemBoardHtml.js.map +1 -0
- package/package.json +99 -0
- package/templates/AGENTS.md +432 -0
- package/templates/BOOT.md +25 -0
- package/templates/BOOTSTRAP.md +50 -0
- package/templates/CHANGELOG_AUDIT.md +74 -0
- package/templates/HEARTBEAT.md +86 -0
- package/templates/IDENTITY.md +27 -0
- package/templates/PR_LAND.md +75 -0
- package/templates/PR_REVIEW.md +97 -0
- package/templates/SOUL.dev.md +52 -0
- package/templates/SOUL.md +81 -0
- package/templates/TOOLS.md +52 -0
- package/templates/USER.md +22 -0
- package/templates/WORKITEM_ANALYSIS.md +31 -0
- package/templates/agents/executor.md +26 -0
- package/templates/agents/plan.md +22 -0
- package/templates/agents/ralph.md +37 -0
- package/templates/agents/review.md +22 -0
- package/templates/agents/team.md +39 -0
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
// ============================================
|
|
2
|
+
// EnactFactory - Auth CLI Handler
|
|
3
|
+
// `enact-factory auth login/status/logout`
|
|
4
|
+
// ============================================
|
|
5
|
+
import { readWorkspaceRootConfig } from '../core/workspaceConfig.js';
|
|
6
|
+
function requireGatewayBaseUrl() {
|
|
7
|
+
const value = readWorkspaceRootConfig()?.gateway?.['gateway_url'];
|
|
8
|
+
if (typeof value === 'string' && value.trim())
|
|
9
|
+
return value;
|
|
10
|
+
throw new Error('Missing [gateway].gateway_url in workspace config.toml');
|
|
11
|
+
}
|
|
12
|
+
const DEFAULT_GATEWAY_BASE_URL = requireGatewayBaseUrl();
|
|
13
|
+
const RESPONSES_BASE_URL = DEFAULT_GATEWAY_BASE_URL;
|
|
14
|
+
const RESPONSES_API_KEY = process.env.ENACT_RESPONSES_API_KEY ?? process.env.ENACT_GATEWAY_API_KEY ?? '';
|
|
15
|
+
function assertSupportedProvider(provider) {
|
|
16
|
+
if (provider === 'responses') {
|
|
17
|
+
return provider;
|
|
18
|
+
}
|
|
19
|
+
console.error(`Unsupported provider: "${provider}". Supported provider: "responses".`);
|
|
20
|
+
process.exit(1);
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Env-based auth setup instructions
|
|
24
|
+
*/
|
|
25
|
+
export async function handleAuthLogin(provider, _opts) {
|
|
26
|
+
const normalized = assertSupportedProvider(provider);
|
|
27
|
+
console.log('OAuth login was removed for HTTP adapters.');
|
|
28
|
+
console.log('');
|
|
29
|
+
console.log('Set workspace config instead:');
|
|
30
|
+
console.log(` [gateway] gateway_url = "${DEFAULT_GATEWAY_BASE_URL}"`);
|
|
31
|
+
console.log(' export ENACT_GATEWAY_API_KEY="your-api-key"');
|
|
32
|
+
console.log('');
|
|
33
|
+
if (normalized === 'responses') {
|
|
34
|
+
console.log('Optional provider-specific overrides:');
|
|
35
|
+
console.log(` # responses adapter uses ${RESPONSES_BASE_URL}`);
|
|
36
|
+
console.log(' export ENACT_RESPONSES_API_KEY="your-api-key"');
|
|
37
|
+
console.log('');
|
|
38
|
+
console.log('Expected endpoint: POST /v1/responses');
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Show env-based auth status
|
|
43
|
+
*/
|
|
44
|
+
export function handleAuthStatus() {
|
|
45
|
+
console.log('Responses provider:');
|
|
46
|
+
console.log(` Base URL: ${RESPONSES_BASE_URL}`);
|
|
47
|
+
console.log(` API key: ${RESPONSES_API_KEY ? maskToken(RESPONSES_API_KEY) : '(not set)'}`);
|
|
48
|
+
console.log('');
|
|
49
|
+
console.log('Shared gateway config:');
|
|
50
|
+
console.log(` [gateway].gateway_url=${DEFAULT_GATEWAY_BASE_URL}`);
|
|
51
|
+
console.log(` ENACT_GATEWAY_API_KEY=${process.env.ENACT_GATEWAY_API_KEY ? maskToken(process.env.ENACT_GATEWAY_API_KEY) : '(not set)'}`);
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Explain how to clear env-based auth
|
|
55
|
+
*/
|
|
56
|
+
export function handleAuthLogout(provider) {
|
|
57
|
+
const normalized = assertSupportedProvider(provider);
|
|
58
|
+
console.log(`No stored auth state exists for "${normalized}".`);
|
|
59
|
+
console.log('Unset the corresponding secret env vars in your shell instead:');
|
|
60
|
+
if (normalized === 'responses') {
|
|
61
|
+
console.log(' unset ENACT_RESPONSES_API_KEY');
|
|
62
|
+
}
|
|
63
|
+
console.log(' unset ENACT_GATEWAY_API_KEY');
|
|
64
|
+
}
|
|
65
|
+
function maskToken(token) {
|
|
66
|
+
if (token.length <= 8)
|
|
67
|
+
return '****';
|
|
68
|
+
return token.slice(0, 4) + '...' + token.slice(-4);
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=authHandler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authHandler.js","sourceRoot":"","sources":["../../src/cli/authHandler.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAC/C,kCAAkC;AAClC,2CAA2C;AAC3C,+CAA+C;AAE/C,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AAEpE,SAAS,qBAAqB;IAC5B,MAAM,KAAK,GAAG,uBAAuB,EAAE,EAAE,OAAO,EAAE,CAAC,aAAa,CAAC,CAAC;IAClE,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,IAAI,EAAE;QAAE,OAAO,KAAK,CAAC;IAC5D,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;AAC5E,CAAC;AAED,MAAM,wBAAwB,GAAG,qBAAqB,EAAE,CAAC;AACzD,MAAM,kBAAkB,GAAG,wBAAwB,CAAC;AACpD,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,uBAAuB,IAAI,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,EAAE,CAAC;AAEzG,SAAS,uBAAuB,CAAC,QAAgB;IAC/C,IAAI,QAAQ,KAAK,WAAW,EAAE,CAAC;QAC7B,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,OAAO,CAAC,KAAK,CAAC,0BAA0B,QAAQ,qCAAqC,CAAC,CAAC;IACvF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,QAAgB,EAAE,KAA8B;IACpF,MAAM,UAAU,GAAG,uBAAuB,CAAC,QAAQ,CAAC,CAAC;IACrD,OAAO,CAAC,GAAG,CAAC,4CAA4C,CAAC,CAAC;IAC1D,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,OAAO,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC;IAC7C,OAAO,CAAC,GAAG,CAAC,8BAA8B,wBAAwB,GAAG,CAAC,CAAC;IACvE,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;IAC7D,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,IAAI,UAAU,KAAK,WAAW,EAAE,CAAC;QAC/B,OAAO,CAAC,GAAG,CAAC,uCAAuC,CAAC,CAAC;QACrD,OAAO,CAAC,GAAG,CAAC,8BAA8B,kBAAkB,EAAE,CAAC,CAAC;QAChE,OAAO,CAAC,GAAG,CAAC,iDAAiD,CAAC,CAAC;QAC/D,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,GAAG,CAAC,uCAAuC,CAAC,CAAC;IACvD,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB;IAC9B,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;IACnC,OAAO,CAAC,GAAG,CAAC,eAAe,kBAAkB,EAAE,CAAC,CAAC;IACjD,OAAO,CAAC,GAAG,CAAC,eAAe,iBAAiB,CAAC,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAC7F,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;IACtC,OAAO,CAAC,GAAG,CAAC,2BAA2B,wBAAwB,EAAE,CAAC,CAAC;IACnE,OAAO,CAAC,GAAG,CAAC,2BAA2B,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;AAC3I,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,QAAgB;IAC/C,MAAM,UAAU,GAAG,uBAAuB,CAAC,QAAQ,CAAC,CAAC;IACrD,OAAO,CAAC,GAAG,CAAC,oCAAoC,UAAU,IAAI,CAAC,CAAC;IAChE,OAAO,CAAC,GAAG,CAAC,gEAAgE,CAAC,CAAC;IAC9E,IAAI,UAAU,KAAK,WAAW,EAAE,CAAC;QAC/B,OAAO,CAAC,GAAG,CAAC,iCAAiC,CAAC,CAAC;IACjD,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC;AAC/C,CAAC;AAED,SAAS,SAAS,CAAC,KAAa;IAC9B,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC;QAAE,OAAO,MAAM,CAAC;IACrC,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AACrD,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export declare function handleCheck(filePath: string | undefined, opts: {
|
|
2
|
+
stats?: boolean;
|
|
3
|
+
deprecated?: boolean;
|
|
4
|
+
untested?: boolean;
|
|
5
|
+
highRisk?: boolean;
|
|
6
|
+
tag?: string;
|
|
7
|
+
search?: string;
|
|
8
|
+
project?: string;
|
|
9
|
+
scan?: boolean;
|
|
10
|
+
bs?: boolean;
|
|
11
|
+
verbose?: boolean;
|
|
12
|
+
tree?: boolean;
|
|
13
|
+
ci?: boolean;
|
|
14
|
+
}): Promise<void>;
|
|
15
|
+
/**
|
|
16
|
+
* enact-factory annotate <qualifiedName> — 엔티티 어노테이션
|
|
17
|
+
*/
|
|
18
|
+
export declare function handleAnnotate(qualifiedName: string, opts: {
|
|
19
|
+
deprecate?: string | boolean;
|
|
20
|
+
status?: string;
|
|
21
|
+
tag?: string;
|
|
22
|
+
untag?: string;
|
|
23
|
+
note?: string;
|
|
24
|
+
risk?: string;
|
|
25
|
+
warn?: string;
|
|
26
|
+
}): Promise<void>;
|
|
27
|
+
//# sourceMappingURL=checkHandler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkHandler.d.ts","sourceRoot":"","sources":["../../src/cli/checkHandler.ts"],"names":[],"mappings":"AAwIA,wBAAsB,WAAW,CAC/B,QAAQ,EAAE,MAAM,GAAG,SAAS,EAC5B,IAAI,EAAE;IACJ,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,EAAE,CAAC,EAAE,OAAO,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,EAAE,CAAC,EAAE,OAAO,CAAC;CACd,GACA,OAAO,CAAC,IAAI,CAAC,CAyVf;AAED;;GAEG;AACH,wBAAsB,cAAc,CAClC,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE;IACJ,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,GACA,OAAO,CAAC,IAAI,CAAC,CAgHf"}
|
|
@@ -0,0 +1,560 @@
|
|
|
1
|
+
// ============================================
|
|
2
|
+
// EnactFactory - CLI Check Handler
|
|
3
|
+
// Created: 2026-04-10
|
|
4
|
+
// Purpose: `enact-factory check` 명령어 — 코드 레지스트리 조회
|
|
5
|
+
// ============================================
|
|
6
|
+
import { readFileSync, existsSync } from 'node:fs';
|
|
7
|
+
import { join } from 'node:path';
|
|
8
|
+
import { getRegistryStore, closeRegistryStore } from '../registry/sqliteStore.js';
|
|
9
|
+
import { scanRepository } from '../registry/entityScanner.js';
|
|
10
|
+
/** package.json name → Cargo.toml → go.mod → 폴더명 순으로 프로젝트 ID 추론 */
|
|
11
|
+
function resolveProjectId(projectPath) {
|
|
12
|
+
// 1. package.json의 name 필드
|
|
13
|
+
const pkgPath = join(projectPath, 'package.json');
|
|
14
|
+
if (existsSync(pkgPath)) {
|
|
15
|
+
try {
|
|
16
|
+
const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8'));
|
|
17
|
+
if (pkg.name && typeof pkg.name === 'string') {
|
|
18
|
+
return pkg.name.replace(/^@[^/]+\//, '');
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
console.warn(`[check] package.json 파싱 실패: ${err instanceof Error ? err.message : String(err)}`);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
// 2. Cargo.toml의 name (Rust)
|
|
26
|
+
const cargoPath = join(projectPath, 'Cargo.toml');
|
|
27
|
+
if (existsSync(cargoPath)) {
|
|
28
|
+
try {
|
|
29
|
+
const cargo = readFileSync(cargoPath, 'utf-8');
|
|
30
|
+
const nameMatch = cargo.match(/^\s*name\s*=\s*"([^"]+)"/m);
|
|
31
|
+
if (nameMatch)
|
|
32
|
+
return nameMatch[1];
|
|
33
|
+
}
|
|
34
|
+
catch (err) {
|
|
35
|
+
console.warn(`[check] Cargo.toml 파싱 실패: ${err instanceof Error ? err.message : String(err)}`);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
// 3. go.mod의 module path (Go)
|
|
39
|
+
const goModPath = join(projectPath, 'go.mod');
|
|
40
|
+
if (existsSync(goModPath)) {
|
|
41
|
+
try {
|
|
42
|
+
const goMod = readFileSync(goModPath, 'utf-8');
|
|
43
|
+
const modMatch = goMod.match(/^module\s+(\S+)/m);
|
|
44
|
+
if (modMatch) {
|
|
45
|
+
const lastSegment = modMatch[1].split('/').pop();
|
|
46
|
+
if (lastSegment)
|
|
47
|
+
return lastSegment;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
catch (err) {
|
|
51
|
+
console.warn(`[check] go.mod 파싱 실패: ${err instanceof Error ? err.message : String(err)}`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
// 4. 폴더명 폴백
|
|
55
|
+
return projectPath.split('/').pop() ?? 'unknown';
|
|
56
|
+
}
|
|
57
|
+
// 색상 헬퍼 (ANSI)
|
|
58
|
+
const c = {
|
|
59
|
+
reset: '\x1b[0m',
|
|
60
|
+
bold: '\x1b[1m',
|
|
61
|
+
dim: '\x1b[2m',
|
|
62
|
+
red: '\x1b[31m',
|
|
63
|
+
green: '\x1b[32m',
|
|
64
|
+
yellow: '\x1b[33m',
|
|
65
|
+
blue: '\x1b[34m',
|
|
66
|
+
magenta: '\x1b[35m',
|
|
67
|
+
cyan: '\x1b[36m',
|
|
68
|
+
gray: '\x1b[90m',
|
|
69
|
+
};
|
|
70
|
+
function statusBadge(status) {
|
|
71
|
+
switch (status) {
|
|
72
|
+
case 'active': return `${c.green}●${c.reset} active`;
|
|
73
|
+
case 'deprecated': return `${c.red}✗${c.reset} deprecated`;
|
|
74
|
+
case 'experimental': return `${c.yellow}◎${c.reset} experimental`;
|
|
75
|
+
case 'planned': return `${c.blue}○${c.reset} planned`;
|
|
76
|
+
case 'broken': return `${c.red}⚠${c.reset} broken`;
|
|
77
|
+
default: return status;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
function riskBadge(risk) {
|
|
81
|
+
switch (risk) {
|
|
82
|
+
case 'high': return `${c.red}HIGH${c.reset}`;
|
|
83
|
+
case 'medium': return `${c.yellow}MED${c.reset}`;
|
|
84
|
+
case 'low': return `${c.green}LOW${c.reset}`;
|
|
85
|
+
default: return risk;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
function severityBadge(sev) {
|
|
89
|
+
switch (sev) {
|
|
90
|
+
case 'critical': return `${c.red}${c.bold}CRITICAL${c.reset}`;
|
|
91
|
+
case 'error': return `${c.red}ERROR${c.reset}`;
|
|
92
|
+
case 'warning': return `${c.yellow}WARNING${c.reset}`;
|
|
93
|
+
case 'info': return `${c.blue}INFO${c.reset}`;
|
|
94
|
+
default: return sev;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
function formatEntity(e, verbose = true) {
|
|
98
|
+
const lines = [];
|
|
99
|
+
const loc = e.lineStart ? `:${e.lineStart}${e.lineEnd ? `-${e.lineEnd}` : ''}` : '';
|
|
100
|
+
const testIcon = e.hasTests ? `${c.green}✓${c.reset}` : `${c.red}✗${c.reset}`;
|
|
101
|
+
lines.push(` ${c.bold}${e.kind}${c.reset} ${c.cyan}${e.name}${c.reset}${c.dim}${loc}${c.reset}` +
|
|
102
|
+
` ${statusBadge(e.status)} test:${testIcon} risk:${riskBadge(e.riskLevel)}`);
|
|
103
|
+
if (verbose) {
|
|
104
|
+
if (e.signature)
|
|
105
|
+
lines.push(` ${c.dim}sig: ${e.signature}${c.reset}`);
|
|
106
|
+
if (e.author)
|
|
107
|
+
lines.push(` ${c.dim}author: ${e.author}${c.reset}`);
|
|
108
|
+
if (e.description)
|
|
109
|
+
lines.push(` ${c.dim}${e.description}${c.reset}`);
|
|
110
|
+
if (e.deprecatedReason)
|
|
111
|
+
lines.push(` ${c.red}reason: ${e.deprecatedReason}${c.reset}`);
|
|
112
|
+
if (e.tags.length > 0) {
|
|
113
|
+
lines.push(` ${c.magenta}tags: ${e.tags.map(t => t.value ? `${t.tag}=${t.value}` : t.tag).join(', ')}${c.reset}`);
|
|
114
|
+
}
|
|
115
|
+
for (const w of e.warnings.filter(w => !w.resolved)) {
|
|
116
|
+
lines.push(` ${severityBadge(w.severity)} [${w.category}] ${w.message}`);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return lines.join('\n');
|
|
120
|
+
}
|
|
121
|
+
function formatEntityCompact(e) {
|
|
122
|
+
const loc = e.lineStart ? `:${e.lineStart}` : '';
|
|
123
|
+
const testIcon = e.hasTests ? '✓' : '✗';
|
|
124
|
+
return ` ${e.kind.padEnd(9)} ${e.name.padEnd(30)} ${e.filePath}${loc} ${e.status.padEnd(12)} test:${testIcon} risk:${e.riskLevel}`;
|
|
125
|
+
}
|
|
126
|
+
export async function handleCheck(filePath, opts) {
|
|
127
|
+
try {
|
|
128
|
+
const store = getRegistryStore();
|
|
129
|
+
// --scan: 레포 전체 스캔 → 레지스트리 동기화
|
|
130
|
+
if (opts.scan) {
|
|
131
|
+
const projectPath = process.cwd();
|
|
132
|
+
const projectId = opts.project ?? resolveProjectId(projectPath);
|
|
133
|
+
console.log(`\n${c.bold}Scanning repository...${c.reset}`);
|
|
134
|
+
console.log(` ${c.dim}path: ${projectPath}${c.reset}`);
|
|
135
|
+
console.log(` ${c.dim}project: ${projectId}${c.reset}\n`);
|
|
136
|
+
const result = await scanRepository(projectPath, projectId, {
|
|
137
|
+
verbose: opts.verbose,
|
|
138
|
+
});
|
|
139
|
+
console.log(`${c.bold}Scan Complete${c.reset}`);
|
|
140
|
+
console.log(`${'─'.repeat(40)}`);
|
|
141
|
+
console.log(` Files scanned: ${c.bold}${result.scanned}${c.reset}`);
|
|
142
|
+
console.log(` Entities found: ${c.bold}${result.extracted}${c.reset}`);
|
|
143
|
+
console.log(` New registered: ${c.green}+${result.registered}${c.reset}`);
|
|
144
|
+
console.log(` Updated: ${c.yellow}~${result.updated}${c.reset}`);
|
|
145
|
+
console.log(` Marked broken: ${result.removed > 0 ? c.red : c.dim}${result.removed}${c.reset}`);
|
|
146
|
+
console.log(` Tests mapped: ${c.cyan}${result.testsMapped}${c.reset}`);
|
|
147
|
+
console.log(` Duration: ${c.dim}${result.durationMs}ms${c.reset}`);
|
|
148
|
+
if (Object.keys(result.languageBreakdown).length > 0) {
|
|
149
|
+
console.log(`\n ${c.dim}By language:${c.reset}`);
|
|
150
|
+
for (const [lang, count] of Object.entries(result.languageBreakdown).sort((a, b) => b[1] - a[1])) {
|
|
151
|
+
console.log(` ${lang.padEnd(12)} ${count} files`);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
if (result.errors.length > 0) {
|
|
155
|
+
console.log(`\n ${c.red}Errors (${result.errors.length}):${c.reset}`);
|
|
156
|
+
for (const err of result.errors.slice(0, 10)) {
|
|
157
|
+
console.log(` ${c.dim}${err}${c.reset}`);
|
|
158
|
+
}
|
|
159
|
+
if (result.errors.length > 10) {
|
|
160
|
+
console.log(` ${c.dim}...and ${result.errors.length - 10} more${c.reset}`);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
// 스캔 후 통계 표시
|
|
164
|
+
const stats = store.getStats(projectId);
|
|
165
|
+
console.log(`\n${c.bold}Registry Status${c.reset}`);
|
|
166
|
+
console.log(` Total: ${stats.total} deprecated: ${stats.deprecated} untested: ${stats.untested} high-risk: ${stats.highRisk} warnings: ${stats.withWarnings}\n`);
|
|
167
|
+
return;
|
|
168
|
+
}
|
|
169
|
+
// --bs: BS 패턴 탐지
|
|
170
|
+
if (opts.bs) {
|
|
171
|
+
const { scanRepository: scanBs } = await import('../registry/bsDetector.js');
|
|
172
|
+
const projectPath = process.cwd();
|
|
173
|
+
console.log(`\n${c.bold}BS Detector${c.reset} — scanning for bad code patterns...`);
|
|
174
|
+
console.log(` ${c.dim}path: ${projectPath}${c.reset}\n`);
|
|
175
|
+
const result = await scanBs(projectPath, { verbose: opts.verbose });
|
|
176
|
+
// 결과 출력
|
|
177
|
+
const statusColor = result.critical > 0 ? c.red : result.warning > 0 ? c.yellow : c.green;
|
|
178
|
+
const statusText = result.critical > 0 ? 'FAIL' : result.warning > 0 ? 'WARN' : 'CLEAN';
|
|
179
|
+
console.log(`${c.bold}BS Scan Result${c.reset}`);
|
|
180
|
+
console.log(`${'─'.repeat(50)}`);
|
|
181
|
+
console.log(` Files scanned: ${c.bold}${result.filesScanned}${c.reset}`);
|
|
182
|
+
console.log(` BS Score: ${statusColor}${c.bold}${result.bsScore.toFixed(1)}${c.reset} / 5.0`);
|
|
183
|
+
console.log(` Status: ${statusColor}${c.bold}${statusText}${c.reset}`);
|
|
184
|
+
console.log(` CRITICAL: ${result.critical > 0 ? c.red : c.green}${result.critical}${c.reset}`);
|
|
185
|
+
console.log(` WARNING: ${result.warning > 0 ? c.yellow : c.green}${result.warning}${c.reset}`);
|
|
186
|
+
console.log(` MINOR: ${result.minor > 0 ? c.dim : c.green}${result.minor}${c.reset}`);
|
|
187
|
+
if (result.workItems.length > 0) {
|
|
188
|
+
// CRITICAL 먼저
|
|
189
|
+
const criticals = result.workItems.filter(i => i.severity === 'critical');
|
|
190
|
+
if (criticals.length > 0) {
|
|
191
|
+
console.log(`\n ${c.red}${c.bold}CRITICAL (즉시 수정 필요)${c.reset}`);
|
|
192
|
+
for (const workItem of criticals) {
|
|
193
|
+
console.log(` ${c.red}${workItem.filePath}:${workItem.line}${c.reset} — ${workItem.message}`);
|
|
194
|
+
console.log(` ${c.dim}${workItem.matchedText}${c.reset}`);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
const warnings = result.workItems.filter(i => i.severity === 'warning');
|
|
198
|
+
if (warnings.length > 0) {
|
|
199
|
+
console.log(`\n ${c.yellow}WARNING (권장 수정)${c.reset}`);
|
|
200
|
+
for (const workItem of warnings.slice(0, 30)) {
|
|
201
|
+
console.log(` ${c.yellow}${workItem.filePath}:${workItem.line}${c.reset} — ${workItem.message}`);
|
|
202
|
+
}
|
|
203
|
+
if (warnings.length > 30) {
|
|
204
|
+
console.log(` ${c.dim}...and ${warnings.length - 30} more${c.reset}`);
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
const minors = result.workItems.filter(i => i.severity === 'minor');
|
|
208
|
+
if (minors.length > 0) {
|
|
209
|
+
console.log(`\n ${c.dim}MINOR (${minors.length}건)${c.reset}`);
|
|
210
|
+
for (const workItem of minors.slice(0, 10)) {
|
|
211
|
+
console.log(` ${c.dim}${workItem.filePath}:${workItem.line} — ${workItem.message}${c.reset}`);
|
|
212
|
+
}
|
|
213
|
+
if (minors.length > 10) {
|
|
214
|
+
console.log(` ${c.dim}...and ${minors.length - 10} more${c.reset}`);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
console.log();
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
// --tree: directory tree with entity counts and risk indicators
|
|
222
|
+
if (opts.tree) {
|
|
223
|
+
const projectId = opts.project ?? resolveProjectId(process.cwd());
|
|
224
|
+
const scopePath = filePath || ''; // optional dir scope
|
|
225
|
+
const { entities } = store.listEntities({ projectId, limit: 50000, offset: 0 });
|
|
226
|
+
// Group entities by directory → file
|
|
227
|
+
const tree = new Map();
|
|
228
|
+
for (const e of entities) {
|
|
229
|
+
if (scopePath && !e.filePath.startsWith(scopePath))
|
|
230
|
+
continue;
|
|
231
|
+
const parts = e.filePath.split('/');
|
|
232
|
+
const fileName = parts.pop();
|
|
233
|
+
const dirPath = parts.join('/') || '.';
|
|
234
|
+
if (!tree.has(dirPath))
|
|
235
|
+
tree.set(dirPath, new Map());
|
|
236
|
+
const dir = tree.get(dirPath);
|
|
237
|
+
if (!dir.has(fileName)) {
|
|
238
|
+
dir.set(fileName, { total: 0, untested: 0, highRisk: 0, deprecated: 0, kinds: new Map() });
|
|
239
|
+
}
|
|
240
|
+
const file = dir.get(fileName);
|
|
241
|
+
file.total++;
|
|
242
|
+
if (!e.hasTests)
|
|
243
|
+
file.untested++;
|
|
244
|
+
if (e.riskLevel === 'high')
|
|
245
|
+
file.highRisk++;
|
|
246
|
+
if (e.status === 'deprecated')
|
|
247
|
+
file.deprecated++;
|
|
248
|
+
file.kinds.set(e.kind, (file.kinds.get(e.kind) || 0) + 1);
|
|
249
|
+
}
|
|
250
|
+
// Sort directories
|
|
251
|
+
const sortedDirs = [...tree.keys()].sort();
|
|
252
|
+
const totalFiles = [...tree.values()].reduce((s, d) => s + d.size, 0);
|
|
253
|
+
const totalEntities = entities.filter(e => !scopePath || e.filePath.startsWith(scopePath)).length;
|
|
254
|
+
console.log(`\n${c.bold}Code Tree${c.reset}${scopePath ? ` (${scopePath})` : ''} — ${totalFiles} files, ${totalEntities} entities\n`);
|
|
255
|
+
for (const dirPath of sortedDirs) {
|
|
256
|
+
const files = tree.get(dirPath);
|
|
257
|
+
const dirTotal = [...files.values()].reduce((s, f) => s + f.total, 0);
|
|
258
|
+
const dirUntested = [...files.values()].reduce((s, f) => s + f.untested, 0);
|
|
259
|
+
const dirHighRisk = [...files.values()].reduce((s, f) => s + f.highRisk, 0);
|
|
260
|
+
// Directory header
|
|
261
|
+
const riskFlag = dirHighRisk > 0 ? ` ${c.red}${dirHighRisk} high-risk${c.reset}` : '';
|
|
262
|
+
console.log(`${c.bold}${dirPath}/${c.reset} ${c.dim}(${dirTotal} entities, ${dirUntested} untested${riskFlag})${c.reset}`);
|
|
263
|
+
// Files in directory
|
|
264
|
+
const sortedFiles = [...files.entries()].sort((a, b) => b[1].total - a[1].total);
|
|
265
|
+
for (const [fileName, info] of sortedFiles) {
|
|
266
|
+
const kindStr = [...info.kinds.entries()].map(([k, n]) => `${n} ${k}`).join(', ');
|
|
267
|
+
const flags = [];
|
|
268
|
+
if (info.highRisk > 0)
|
|
269
|
+
flags.push(`${c.red}${info.highRisk} high-risk${c.reset}`);
|
|
270
|
+
if (info.deprecated > 0)
|
|
271
|
+
flags.push(`${c.red}${info.deprecated} deprecated${c.reset}`);
|
|
272
|
+
const flagStr = flags.length ? ' ' + flags.join(' ') : '';
|
|
273
|
+
const testPct = info.total > 0 ? Math.round(((info.total - info.untested) / info.total) * 100) : 0;
|
|
274
|
+
const testColor = testPct === 100 ? c.green : testPct > 50 ? c.yellow : c.red;
|
|
275
|
+
console.log(` ${c.cyan}${fileName}${c.reset} ${c.dim}${kindStr}${c.reset} ${testColor}${testPct}% tested${c.reset}${flagStr}`);
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
console.log();
|
|
279
|
+
return;
|
|
280
|
+
}
|
|
281
|
+
// --ci: CI/CD mode — machine-readable JSON, exit code 1 on critical workItems
|
|
282
|
+
if (opts.ci) {
|
|
283
|
+
const projectPath = process.cwd();
|
|
284
|
+
const projectId = opts.project ?? resolveProjectId(projectPath);
|
|
285
|
+
// Run BS scan
|
|
286
|
+
const { scanRepository: scanBs } = await import('../registry/bsDetector.js');
|
|
287
|
+
const bsResult = await scanBs(projectPath, { verbose: false });
|
|
288
|
+
// Registry stats
|
|
289
|
+
const stats = store.getStats(projectId);
|
|
290
|
+
const result = {
|
|
291
|
+
project: projectId,
|
|
292
|
+
path: projectPath,
|
|
293
|
+
registry: {
|
|
294
|
+
total: stats.total,
|
|
295
|
+
deprecated: stats.deprecated,
|
|
296
|
+
untested: stats.untested,
|
|
297
|
+
highRisk: stats.highRisk,
|
|
298
|
+
warnings: stats.withWarnings,
|
|
299
|
+
},
|
|
300
|
+
bs: {
|
|
301
|
+
filesScanned: bsResult.filesScanned,
|
|
302
|
+
score: bsResult.bsScore,
|
|
303
|
+
critical: bsResult.critical,
|
|
304
|
+
warning: bsResult.warning,
|
|
305
|
+
minor: bsResult.minor,
|
|
306
|
+
},
|
|
307
|
+
pass: bsResult.critical === 0,
|
|
308
|
+
};
|
|
309
|
+
console.log(JSON.stringify(result, null, 2));
|
|
310
|
+
// Exit code 1 if critical workItems
|
|
311
|
+
if (bsResult.critical > 0) {
|
|
312
|
+
process.exitCode = 1;
|
|
313
|
+
}
|
|
314
|
+
return;
|
|
315
|
+
}
|
|
316
|
+
// --stats: full statistics
|
|
317
|
+
if (opts.stats) {
|
|
318
|
+
const stats = store.getStats(opts.project);
|
|
319
|
+
console.log(`\n${c.bold}Registry Stats${c.reset}`);
|
|
320
|
+
console.log(`${'─'.repeat(40)}`);
|
|
321
|
+
console.log(` Total entities: ${c.bold}${stats.total}${c.reset}`);
|
|
322
|
+
console.log(` Deprecated: ${stats.deprecated > 0 ? c.red : c.green}${stats.deprecated}${c.reset}`);
|
|
323
|
+
console.log(` Untested: ${stats.untested > 0 ? c.yellow : c.green}${stats.untested}${c.reset}`);
|
|
324
|
+
console.log(` High risk: ${stats.highRisk > 0 ? c.red : c.green}${stats.highRisk}${c.reset}`);
|
|
325
|
+
console.log(` With warnings: ${stats.withWarnings > 0 ? c.yellow : c.green}${stats.withWarnings}${c.reset}`);
|
|
326
|
+
if (stats.byKind.length > 0) {
|
|
327
|
+
console.log(`\n ${c.dim}By kind:${c.reset}`);
|
|
328
|
+
for (const { kind, count } of stats.byKind) {
|
|
329
|
+
console.log(` ${kind.padEnd(12)} ${count}`);
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
if (stats.byStatus.length > 0) {
|
|
333
|
+
console.log(`\n ${c.dim}By status:${c.reset}`);
|
|
334
|
+
for (const { status, count } of stats.byStatus) {
|
|
335
|
+
console.log(` ${status.padEnd(14)} ${count}`);
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
console.log();
|
|
339
|
+
return;
|
|
340
|
+
}
|
|
341
|
+
// --deprecated
|
|
342
|
+
if (opts.deprecated) {
|
|
343
|
+
const entities = store.deprecatedEntities(opts.project);
|
|
344
|
+
console.log(`\n${c.bold}Deprecated Entities${c.reset} (${entities.length})\n`);
|
|
345
|
+
if (entities.length === 0) {
|
|
346
|
+
console.log(` ${c.green}None${c.reset}\n`);
|
|
347
|
+
}
|
|
348
|
+
else {
|
|
349
|
+
for (const e of entities)
|
|
350
|
+
console.log(formatEntity(e));
|
|
351
|
+
console.log();
|
|
352
|
+
}
|
|
353
|
+
return;
|
|
354
|
+
}
|
|
355
|
+
// --untested
|
|
356
|
+
if (opts.untested) {
|
|
357
|
+
const entities = store.untestedEntities(opts.project);
|
|
358
|
+
console.log(`\n${c.bold}Untested Active Entities${c.reset} (${entities.length})\n`);
|
|
359
|
+
if (entities.length === 0) {
|
|
360
|
+
console.log(` ${c.green}All tested${c.reset}\n`);
|
|
361
|
+
}
|
|
362
|
+
else {
|
|
363
|
+
for (const e of entities)
|
|
364
|
+
console.log(formatEntityCompact(e));
|
|
365
|
+
console.log();
|
|
366
|
+
}
|
|
367
|
+
return;
|
|
368
|
+
}
|
|
369
|
+
// --high-risk
|
|
370
|
+
if (opts.highRisk) {
|
|
371
|
+
const entities = store.highRiskEntities(opts.project);
|
|
372
|
+
console.log(`\n${c.bold}High Risk Entities${c.reset} (${entities.length})\n`);
|
|
373
|
+
if (entities.length === 0) {
|
|
374
|
+
console.log(` ${c.green}None${c.reset}\n`);
|
|
375
|
+
}
|
|
376
|
+
else {
|
|
377
|
+
for (const e of entities)
|
|
378
|
+
console.log(formatEntity(e));
|
|
379
|
+
console.log();
|
|
380
|
+
}
|
|
381
|
+
return;
|
|
382
|
+
}
|
|
383
|
+
// --tag
|
|
384
|
+
if (opts.tag) {
|
|
385
|
+
const entities = store.entitiesByTag(opts.tag);
|
|
386
|
+
console.log(`\n${c.bold}Entities tagged "${opts.tag}"${c.reset} (${entities.length})\n`);
|
|
387
|
+
if (entities.length === 0) {
|
|
388
|
+
console.log(` ${c.dim}No entities with tag "${opts.tag}"${c.reset}\n`);
|
|
389
|
+
}
|
|
390
|
+
else {
|
|
391
|
+
for (const e of entities)
|
|
392
|
+
console.log(formatEntityCompact(e));
|
|
393
|
+
console.log();
|
|
394
|
+
}
|
|
395
|
+
return;
|
|
396
|
+
}
|
|
397
|
+
// --search
|
|
398
|
+
if (opts.search) {
|
|
399
|
+
const entities = store.searchEntities(opts.search);
|
|
400
|
+
console.log(`\n${c.bold}Search: "${opts.search}"${c.reset} (${entities.length} results)\n`);
|
|
401
|
+
if (entities.length === 0) {
|
|
402
|
+
console.log(` ${c.dim}No matches${c.reset}\n`);
|
|
403
|
+
}
|
|
404
|
+
else {
|
|
405
|
+
for (const e of entities)
|
|
406
|
+
console.log(formatEntity(e));
|
|
407
|
+
console.log();
|
|
408
|
+
}
|
|
409
|
+
return;
|
|
410
|
+
}
|
|
411
|
+
// 파일 경로 지정: fileBrief
|
|
412
|
+
if (filePath) {
|
|
413
|
+
const brief = store.fileBrief(filePath);
|
|
414
|
+
console.log(`\n${c.bold}File Brief: ${filePath}${c.reset}`);
|
|
415
|
+
console.log(`${'─'.repeat(40)}`);
|
|
416
|
+
console.log(` ${c.dim}${brief.summary}${c.reset}\n`);
|
|
417
|
+
if (brief.entities.length === 0) {
|
|
418
|
+
console.log(` ${c.dim}No registered entities for this file.${c.reset}`);
|
|
419
|
+
console.log(` ${c.dim}Use \`registerEntity\` mutation to add entries.${c.reset}\n`);
|
|
420
|
+
}
|
|
421
|
+
else {
|
|
422
|
+
for (const e of brief.entities)
|
|
423
|
+
console.log(formatEntity(e));
|
|
424
|
+
console.log();
|
|
425
|
+
}
|
|
426
|
+
return;
|
|
427
|
+
}
|
|
428
|
+
// 인자 없이 호출 시: 간단 통계 + 도움말
|
|
429
|
+
const stats = store.getStats();
|
|
430
|
+
if (stats.total === 0) {
|
|
431
|
+
console.log(`\n${c.bold}Code Registry${c.reset}: empty`);
|
|
432
|
+
console.log(` ${c.dim}Register entities via: enact-factory check --scan${c.reset}`);
|
|
433
|
+
console.log(` ${c.dim}or use: enact-factory check --help${c.reset}\n`);
|
|
434
|
+
}
|
|
435
|
+
else {
|
|
436
|
+
console.log(`\n${c.bold}Code Registry${c.reset}: ${stats.total} entities`);
|
|
437
|
+
console.log(` ${stats.deprecated} deprecated, ${stats.untested} untested, ${stats.highRisk} high-risk, ${stats.withWarnings} with warnings`);
|
|
438
|
+
console.log(`\n ${c.dim}Usage:${c.reset}`);
|
|
439
|
+
console.log(` ${c.dim} enact-factory check <file> ${c.reset}File brief`);
|
|
440
|
+
console.log(` ${c.dim} enact-factory check --stats ${c.reset}Full statistics`);
|
|
441
|
+
console.log(` ${c.dim} enact-factory check --deprecated ${c.reset}Deprecated list`);
|
|
442
|
+
console.log(` ${c.dim} enact-factory check --untested ${c.reset}Untested list`);
|
|
443
|
+
console.log(` ${c.dim} enact-factory check --search <q> ${c.reset}Full-text search\n`);
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
finally {
|
|
447
|
+
closeRegistryStore();
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
/**
|
|
451
|
+
* enact-factory annotate <qualifiedName> — 엔티티 어노테이션
|
|
452
|
+
*/
|
|
453
|
+
export async function handleAnnotate(qualifiedName, opts) {
|
|
454
|
+
try {
|
|
455
|
+
const store = getRegistryStore();
|
|
456
|
+
// qualified name으로 검색, 없으면 FTS 검색
|
|
457
|
+
let entity = store.getEntityByName(qualifiedName);
|
|
458
|
+
if (!entity) {
|
|
459
|
+
// 부분 매칭 시도: name만으로 검색
|
|
460
|
+
const results = store.searchEntities(qualifiedName, 5);
|
|
461
|
+
if (results.length === 0) {
|
|
462
|
+
console.error(`${c.red}Entity not found: "${qualifiedName}"${c.reset}`);
|
|
463
|
+
console.error(`${c.dim}Use qualified name (file::name) or search with: enact-factory check --search <query>${c.reset}`);
|
|
464
|
+
process.exit(1);
|
|
465
|
+
}
|
|
466
|
+
if (results.length === 1) {
|
|
467
|
+
entity = results[0];
|
|
468
|
+
}
|
|
469
|
+
else {
|
|
470
|
+
console.log(`${c.yellow}Multiple matches for "${qualifiedName}":${c.reset}\n`);
|
|
471
|
+
for (const e of results) {
|
|
472
|
+
console.log(` ${c.cyan}${e.qualifiedName}${c.reset} ${e.kind} ${statusBadge(e.status)}`);
|
|
473
|
+
}
|
|
474
|
+
console.log(`\n${c.dim}Use the full qualified name to annotate a specific entity.${c.reset}`);
|
|
475
|
+
return;
|
|
476
|
+
}
|
|
477
|
+
}
|
|
478
|
+
console.log(`\n${c.bold}Annotating:${c.reset} ${c.cyan}${entity.qualifiedName}${c.reset}\n`);
|
|
479
|
+
let changed = false;
|
|
480
|
+
// --deprecate
|
|
481
|
+
if (opts.deprecate !== undefined) {
|
|
482
|
+
const reason = typeof opts.deprecate === 'string' ? opts.deprecate : undefined;
|
|
483
|
+
store.deprecateEntity(entity.id, reason);
|
|
484
|
+
console.log(` ${c.red}✗${c.reset} Deprecated${reason ? `: ${reason}` : ''}`);
|
|
485
|
+
changed = true;
|
|
486
|
+
}
|
|
487
|
+
// --status
|
|
488
|
+
if (opts.status) {
|
|
489
|
+
const validStatuses = ['active', 'deprecated', 'experimental', 'planned', 'broken'];
|
|
490
|
+
if (!validStatuses.includes(opts.status)) {
|
|
491
|
+
console.error(` ${c.red}Invalid status: ${opts.status}. Valid: ${validStatuses.join(', ')}${c.reset}`);
|
|
492
|
+
}
|
|
493
|
+
else {
|
|
494
|
+
store.changeEntityStatus(entity.id, opts.status);
|
|
495
|
+
console.log(` ${statusBadge(opts.status)} Status changed`);
|
|
496
|
+
changed = true;
|
|
497
|
+
}
|
|
498
|
+
}
|
|
499
|
+
// --tag
|
|
500
|
+
if (opts.tag) {
|
|
501
|
+
const [tagKey, tagValue] = opts.tag.split('=', 2);
|
|
502
|
+
store.addTag(entity.id, tagKey, tagValue);
|
|
503
|
+
console.log(` ${c.magenta}+${c.reset} Tag: ${tagKey}${tagValue ? `=${tagValue}` : ''}`);
|
|
504
|
+
changed = true;
|
|
505
|
+
}
|
|
506
|
+
// --untag
|
|
507
|
+
if (opts.untag) {
|
|
508
|
+
store.removeTag(entity.id, opts.untag);
|
|
509
|
+
console.log(` ${c.dim}-${c.reset} Removed tag: ${opts.untag}`);
|
|
510
|
+
changed = true;
|
|
511
|
+
}
|
|
512
|
+
// --note
|
|
513
|
+
if (opts.note) {
|
|
514
|
+
store.addEvent(entity.id, 'note_added', { content: opts.note, actor: 'cli' });
|
|
515
|
+
console.log(` ${c.blue}📝${c.reset} Note added`);
|
|
516
|
+
changed = true;
|
|
517
|
+
}
|
|
518
|
+
// --risk
|
|
519
|
+
if (opts.risk) {
|
|
520
|
+
const validRisks = ['low', 'medium', 'high'];
|
|
521
|
+
if (!validRisks.includes(opts.risk)) {
|
|
522
|
+
console.error(` ${c.red}Invalid risk: ${opts.risk}. Valid: ${validRisks.join(', ')}${c.reset}`);
|
|
523
|
+
}
|
|
524
|
+
else {
|
|
525
|
+
store.updateEntity(entity.id, { riskLevel: opts.risk }, 'cli');
|
|
526
|
+
console.log(` Risk: ${riskBadge(opts.risk)}`);
|
|
527
|
+
changed = true;
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
// --warn "severity/category: message"
|
|
531
|
+
if (opts.warn) {
|
|
532
|
+
const warnMatch = opts.warn.match(/^(info|warning|error|critical)\/(security|performance|correctness|style):\s*(.+)/);
|
|
533
|
+
if (!warnMatch) {
|
|
534
|
+
console.error(` ${c.red}Invalid warning format. Use: severity/category: message${c.reset}`);
|
|
535
|
+
console.error(` ${c.dim}Example: --warn "error/security: SQL injection risk"${c.reset}`);
|
|
536
|
+
}
|
|
537
|
+
else {
|
|
538
|
+
store.addWarning(entity.id, warnMatch[1], warnMatch[2], warnMatch[3]);
|
|
539
|
+
console.log(` ${severityBadge(warnMatch[1])} [${warnMatch[2]}] ${warnMatch[3]}`);
|
|
540
|
+
changed = true;
|
|
541
|
+
}
|
|
542
|
+
}
|
|
543
|
+
if (!changed) {
|
|
544
|
+
console.log(` ${c.dim}No changes. Use --deprecate, --status, --tag, --note, --risk, or --warn${c.reset}`);
|
|
545
|
+
}
|
|
546
|
+
// 변경 후 엔티티 상태 표시
|
|
547
|
+
if (changed) {
|
|
548
|
+
const updated = store.getEntity(entity.id);
|
|
549
|
+
if (updated) {
|
|
550
|
+
console.log(`\n${c.dim}Updated state:${c.reset}`);
|
|
551
|
+
console.log(formatEntity(updated));
|
|
552
|
+
}
|
|
553
|
+
}
|
|
554
|
+
console.log();
|
|
555
|
+
}
|
|
556
|
+
finally {
|
|
557
|
+
closeRegistryStore();
|
|
558
|
+
}
|
|
559
|
+
}
|
|
560
|
+
//# sourceMappingURL=checkHandler.js.map
|