reviewflow 3.0.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/CHANGELOG.md +271 -0
- package/LICENSE +21 -0
- package/README.md +209 -0
- package/dist/claude/invoker.d.ts +3 -0
- package/dist/claude/invoker.d.ts.map +1 -0
- package/dist/claude/invoker.js +4 -0
- package/dist/claude/invoker.js.map +1 -0
- package/dist/claude/progressParser.d.ts +3 -0
- package/dist/claude/progressParser.d.ts.map +1 -0
- package/dist/claude/progressParser.js +4 -0
- package/dist/claude/progressParser.js.map +1 -0
- package/dist/cli/parseCliArgs.d.ts +6 -0
- package/dist/cli/parseCliArgs.d.ts.map +1 -0
- package/dist/cli/parseCliArgs.js +13 -0
- package/dist/cli/parseCliArgs.js.map +1 -0
- package/dist/config/loader.d.ts +3 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +4 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/projectConfig.d.ts +30 -0
- package/dist/config/projectConfig.d.ts.map +1 -0
- package/dist/config/projectConfig.js +89 -0
- package/dist/config/projectConfig.js.map +1 -0
- package/dist/entities/diffMetadata/diffMetadata.gateway.d.ts +5 -0
- package/dist/entities/diffMetadata/diffMetadata.gateway.d.ts.map +1 -0
- package/dist/entities/diffMetadata/diffMetadata.gateway.js +2 -0
- package/dist/entities/diffMetadata/diffMetadata.gateway.js.map +1 -0
- package/dist/entities/github/githubPullRequestEvent.guard.d.ts +199 -0
- package/dist/entities/github/githubPullRequestEvent.guard.d.ts.map +1 -0
- package/dist/entities/github/githubPullRequestEvent.guard.js +28 -0
- package/dist/entities/github/githubPullRequestEvent.guard.js.map +1 -0
- package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.d.ts +231 -0
- package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.d.ts.map +1 -0
- package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.js +52 -0
- package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.js.map +1 -0
- package/dist/entities/job/jobContext.gateway.d.ts +10 -0
- package/dist/entities/job/jobContext.gateway.d.ts.map +1 -0
- package/dist/entities/job/jobContext.gateway.js +2 -0
- package/dist/entities/job/jobContext.gateway.js.map +1 -0
- package/dist/entities/progress/agentDefinition.type.d.ts +7 -0
- package/dist/entities/progress/agentDefinition.type.d.ts.map +1 -0
- package/dist/entities/progress/agentDefinition.type.js +18 -0
- package/dist/entities/progress/agentDefinition.type.js.map +1 -0
- package/dist/entities/progress/progress.calculator.d.ts +3 -0
- package/dist/entities/progress/progress.calculator.d.ts.map +1 -0
- package/dist/entities/progress/progress.calculator.js +17 -0
- package/dist/entities/progress/progress.calculator.js.map +1 -0
- package/dist/entities/progress/progress.factory.d.ts +4 -0
- package/dist/entities/progress/progress.factory.d.ts.map +1 -0
- package/dist/entities/progress/progress.factory.js +15 -0
- package/dist/entities/progress/progress.factory.js.map +1 -0
- package/dist/entities/progress/progress.gateway.d.ts +12 -0
- package/dist/entities/progress/progress.gateway.d.ts.map +1 -0
- package/dist/entities/progress/progress.gateway.js +2 -0
- package/dist/entities/progress/progress.gateway.js.map +1 -0
- package/dist/entities/progress/progress.type.d.ts +28 -0
- package/dist/entities/progress/progress.type.d.ts.map +1 -0
- package/dist/entities/progress/progress.type.js +2 -0
- package/dist/entities/progress/progress.type.js.map +1 -0
- package/dist/entities/review/reviewScore.valueObject.d.ts +25 -0
- package/dist/entities/review/reviewScore.valueObject.d.ts.map +1 -0
- package/dist/entities/review/reviewScore.valueObject.js +60 -0
- package/dist/entities/review/reviewScore.valueObject.js.map +1 -0
- package/dist/entities/reviewAction/reviewAction.d.ts +12 -0
- package/dist/entities/reviewAction/reviewAction.d.ts.map +1 -0
- package/dist/entities/reviewAction/reviewAction.gateway.d.ts +19 -0
- package/dist/entities/reviewAction/reviewAction.gateway.d.ts.map +1 -0
- package/dist/entities/reviewAction/reviewAction.gateway.js +2 -0
- package/dist/entities/reviewAction/reviewAction.gateway.js.map +1 -0
- package/dist/entities/reviewAction/reviewAction.guard.d.ts +27 -0
- package/dist/entities/reviewAction/reviewAction.guard.d.ts.map +1 -0
- package/dist/entities/reviewAction/reviewAction.guard.js +8 -0
- package/dist/entities/reviewAction/reviewAction.guard.js.map +1 -0
- package/dist/entities/reviewAction/reviewAction.js +2 -0
- package/dist/entities/reviewAction/reviewAction.js.map +1 -0
- package/dist/entities/reviewAction/reviewAction.schema.d.ts +51 -0
- package/dist/entities/reviewAction/reviewAction.schema.d.ts.map +1 -0
- package/dist/entities/reviewAction/reviewAction.schema.js +37 -0
- package/dist/entities/reviewAction/reviewAction.schema.js.map +1 -0
- package/dist/entities/reviewContext/reviewContext.d.ts +62 -0
- package/dist/entities/reviewContext/reviewContext.d.ts.map +1 -0
- package/dist/entities/reviewContext/reviewContext.gateway.d.ts +16 -0
- package/dist/entities/reviewContext/reviewContext.gateway.d.ts.map +1 -0
- package/dist/entities/reviewContext/reviewContext.gateway.js +2 -0
- package/dist/entities/reviewContext/reviewContext.gateway.js.map +1 -0
- package/dist/entities/reviewContext/reviewContext.js +2 -0
- package/dist/entities/reviewContext/reviewContext.js.map +1 -0
- package/dist/entities/reviewContext/reviewContext.schema.d.ts +122 -0
- package/dist/entities/reviewContext/reviewContext.schema.d.ts.map +1 -0
- package/dist/entities/reviewContext/reviewContext.schema.js +42 -0
- package/dist/entities/reviewContext/reviewContext.schema.js.map +1 -0
- package/dist/entities/reviewContext/reviewContextAction.guard.d.ts +247 -0
- package/dist/entities/reviewContext/reviewContextAction.guard.d.ts.map +1 -0
- package/dist/entities/reviewContext/reviewContextAction.guard.js +28 -0
- package/dist/entities/reviewContext/reviewContextAction.guard.js.map +1 -0
- package/dist/entities/reviewContext/reviewContextAction.schema.d.ts +16 -0
- package/dist/entities/reviewContext/reviewContextAction.schema.d.ts.map +1 -0
- package/dist/entities/reviewContext/reviewContextAction.schema.js +13 -0
- package/dist/entities/reviewContext/reviewContextAction.schema.js.map +1 -0
- package/dist/entities/reviewRequest/reviewRequest.entity.d.ts +37 -0
- package/dist/entities/reviewRequest/reviewRequest.entity.d.ts.map +1 -0
- package/dist/entities/reviewRequest/reviewRequest.entity.js +24 -0
- package/dist/entities/reviewRequest/reviewRequest.entity.js.map +1 -0
- package/dist/entities/reviewRequest/reviewRequest.guard.d.ts +20 -0
- package/dist/entities/reviewRequest/reviewRequest.guard.d.ts.map +1 -0
- package/dist/entities/reviewRequest/reviewRequest.guard.js +11 -0
- package/dist/entities/reviewRequest/reviewRequest.guard.js.map +1 -0
- package/dist/entities/reviewRequest/reviewRequestState.valueObject.d.ts +26 -0
- package/dist/entities/reviewRequest/reviewRequestState.valueObject.d.ts.map +1 -0
- package/dist/entities/reviewRequest/reviewRequestState.valueObject.js +61 -0
- package/dist/entities/reviewRequest/reviewRequestState.valueObject.js.map +1 -0
- package/dist/entities/shared/duration.valueObject.d.ts +21 -0
- package/dist/entities/shared/duration.valueObject.d.ts.map +1 -0
- package/dist/entities/shared/duration.valueObject.js +60 -0
- package/dist/entities/shared/duration.valueObject.js.map +1 -0
- package/dist/entities/threadFetch/threadFetch.gateway.d.ts +5 -0
- package/dist/entities/threadFetch/threadFetch.gateway.d.ts.map +1 -0
- package/dist/entities/threadFetch/threadFetch.gateway.js +2 -0
- package/dist/entities/threadFetch/threadFetch.gateway.js.map +1 -0
- package/dist/entities/tracking/assignmentInfo.d.ts +6 -0
- package/dist/entities/tracking/assignmentInfo.d.ts.map +1 -0
- package/dist/entities/tracking/assignmentInfo.js +2 -0
- package/dist/entities/tracking/assignmentInfo.js.map +1 -0
- package/dist/entities/tracking/mrTrackingData.d.ts +19 -0
- package/dist/entities/tracking/mrTrackingData.d.ts.map +1 -0
- package/dist/entities/tracking/mrTrackingData.js +11 -0
- package/dist/entities/tracking/mrTrackingData.js.map +1 -0
- package/dist/entities/tracking/reviewEvent.d.ts +12 -0
- package/dist/entities/tracking/reviewEvent.d.ts.map +1 -0
- package/dist/entities/tracking/reviewEvent.js +2 -0
- package/dist/entities/tracking/reviewEvent.js.map +1 -0
- package/dist/entities/tracking/trackedMr.d.ts +33 -0
- package/dist/entities/tracking/trackedMr.d.ts.map +1 -0
- package/dist/entities/tracking/trackedMr.js +4 -0
- package/dist/entities/tracking/trackedMr.js.map +1 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts +30 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -0
- package/dist/frameworks/claude/claudeInvoker.js +500 -0
- package/dist/frameworks/claude/claudeInvoker.js.map +1 -0
- package/dist/frameworks/claude/progressParser.d.ts +70 -0
- package/dist/frameworks/claude/progressParser.d.ts.map +1 -0
- package/dist/frameworks/claude/progressParser.js +196 -0
- package/dist/frameworks/claude/progressParser.js.map +1 -0
- package/dist/frameworks/config/configLoader.d.ts +34 -0
- package/dist/frameworks/config/configLoader.d.ts.map +1 -0
- package/dist/frameworks/config/configLoader.js +182 -0
- package/dist/frameworks/config/configLoader.js.map +1 -0
- package/dist/frameworks/logging/logBuffer.d.ts +38 -0
- package/dist/frameworks/logging/logBuffer.d.ts.map +1 -0
- package/dist/frameworks/logging/logBuffer.js +72 -0
- package/dist/frameworks/logging/logBuffer.js.map +1 -0
- package/dist/frameworks/queue/pQueueAdapter.d.ts +127 -0
- package/dist/frameworks/queue/pQueueAdapter.d.ts.map +1 -0
- package/dist/frameworks/queue/pQueueAdapter.js +276 -0
- package/dist/frameworks/queue/pQueueAdapter.js.map +1 -0
- package/dist/frameworks/settings/runtimeSettings.d.ts +12 -0
- package/dist/frameworks/settings/runtimeSettings.d.ts.map +1 -0
- package/dist/frameworks/settings/runtimeSettings.js +19 -0
- package/dist/frameworks/settings/runtimeSettings.js.map +1 -0
- package/dist/interface-adapters/adapters/githubPullRequest.adapter.d.ts +6 -0
- package/dist/interface-adapters/adapters/githubPullRequest.adapter.d.ts.map +1 -0
- package/dist/interface-adapters/adapters/githubPullRequest.adapter.js +27 -0
- package/dist/interface-adapters/adapters/githubPullRequest.adapter.js.map +1 -0
- package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.d.ts +6 -0
- package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.d.ts.map +1 -0
- package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.js +35 -0
- package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.js.map +1 -0
- package/dist/interface-adapters/adapters/platformAdapter.d.ts +9 -0
- package/dist/interface-adapters/adapters/platformAdapter.d.ts.map +1 -0
- package/dist/interface-adapters/adapters/platformAdapter.js +16 -0
- package/dist/interface-adapters/adapters/platformAdapter.js.map +1 -0
- package/dist/interface-adapters/controllers/http/cliStatus.routes.d.ts +3 -0
- package/dist/interface-adapters/controllers/http/cliStatus.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/cliStatus.routes.js +173 -0
- package/dist/interface-adapters/controllers/http/cliStatus.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/health.routes.d.ts +9 -0
- package/dist/interface-adapters/controllers/http/health.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/health.routes.js +23 -0
- package/dist/interface-adapters/controllers/http/health.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/index.d.ts +6 -0
- package/dist/interface-adapters/controllers/http/index.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/index.js +6 -0
- package/dist/interface-adapters/controllers/http/index.js.map +1 -0
- package/dist/interface-adapters/controllers/http/logs.routes.d.ts +3 -0
- package/dist/interface-adapters/controllers/http/logs.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/logs.routes.js +12 -0
- package/dist/interface-adapters/controllers/http/logs.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/mrTracking.routes.d.ts +8 -0
- package/dist/interface-adapters/controllers/http/mrTracking.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/mrTracking.routes.js +63 -0
- package/dist/interface-adapters/controllers/http/mrTracking.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.d.ts +12 -0
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js +265 -0
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/projectConfig.routes.d.ts +3 -0
- package/dist/interface-adapters/controllers/http/projectConfig.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/projectConfig.routes.js +75 -0
- package/dist/interface-adapters/controllers/http/projectConfig.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/reviews.routes.d.ts +18 -0
- package/dist/interface-adapters/controllers/http/reviews.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/reviews.routes.js +96 -0
- package/dist/interface-adapters/controllers/http/reviews.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/settings.routes.d.ts +3 -0
- package/dist/interface-adapters/controllers/http/settings.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/settings.routes.js +21 -0
- package/dist/interface-adapters/controllers/http/settings.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/stats.routes.d.ts +13 -0
- package/dist/interface-adapters/controllers/http/stats.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/stats.routes.js +37 -0
- package/dist/interface-adapters/controllers/http/stats.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/mcp/addAction.handler.d.ts +4 -0
- package/dist/interface-adapters/controllers/mcp/addAction.handler.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/mcp/addAction.handler.js +87 -0
- package/dist/interface-adapters/controllers/mcp/addAction.handler.js.map +1 -0
- package/dist/interface-adapters/controllers/mcp/completeAgent.handler.d.ts +4 -0
- package/dist/interface-adapters/controllers/mcp/completeAgent.handler.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/mcp/completeAgent.handler.js +62 -0
- package/dist/interface-adapters/controllers/mcp/completeAgent.handler.js.map +1 -0
- package/dist/interface-adapters/controllers/mcp/getThreads.handler.d.ts +4 -0
- package/dist/interface-adapters/controllers/mcp/getThreads.handler.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/mcp/getThreads.handler.js +32 -0
- package/dist/interface-adapters/controllers/mcp/getThreads.handler.js.map +1 -0
- package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.d.ts +4 -0
- package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.js +28 -0
- package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.js.map +1 -0
- package/dist/interface-adapters/controllers/mcp/setPhase.handler.d.ts +4 -0
- package/dist/interface-adapters/controllers/mcp/setPhase.handler.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/mcp/setPhase.handler.js +60 -0
- package/dist/interface-adapters/controllers/mcp/setPhase.handler.js.map +1 -0
- package/dist/interface-adapters/controllers/mcp/startAgent.handler.d.ts +4 -0
- package/dist/interface-adapters/controllers/mcp/startAgent.handler.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/mcp/startAgent.handler.js +40 -0
- package/dist/interface-adapters/controllers/mcp/startAgent.handler.js.map +1 -0
- package/dist/interface-adapters/controllers/webhook/eventFilter.d.ts +71 -0
- package/dist/interface-adapters/controllers/webhook/eventFilter.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/webhook/eventFilter.js +252 -0
- package/dist/interface-adapters/controllers/webhook/eventFilter.js.map +1 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.d.ts +5 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.js +266 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.js.map +1 -0
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts +5 -0
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.js +461 -0
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.d.ts +7 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.js +71 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.d.ts +7 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.js +58 -0
- package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.d.ts +9 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.js +16 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.d.ts +9 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.js +18 -0
- package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.d.ts +10 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.js +81 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.d.ts +22 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.js +142 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts +8 -0
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.js +37 -0
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.js.map +1 -0
- package/dist/interface-adapters/gateways/jobContext.memory.gateway.d.ts +8 -0
- package/dist/interface-adapters/gateways/jobContext.memory.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/jobContext.memory.gateway.js +13 -0
- package/dist/interface-adapters/gateways/jobContext.memory.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.d.ts +14 -0
- package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.js +87 -0
- package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts +18 -0
- package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/reviewFile.gateway.js +2 -0
- package/dist/interface-adapters/gateways/reviewFile.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.d.ts +13 -0
- package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.js +73 -0
- package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts +19 -0
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.js +2 -0
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/stats.gateway.d.ts +7 -0
- package/dist/interface-adapters/gateways/stats.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/stats.gateway.js +2 -0
- package/dist/interface-adapters/gateways/stats.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/threadFetch.github.gateway.d.ts +10 -0
- package/dist/interface-adapters/gateways/threadFetch.github.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/threadFetch.github.gateway.js +33 -0
- package/dist/interface-adapters/gateways/threadFetch.github.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts +10 -0
- package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.js +30 -0
- package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.js.map +1 -0
- package/dist/interface-adapters/presenters/jobStatus.presenter.d.ts +29 -0
- package/dist/interface-adapters/presenters/jobStatus.presenter.d.ts.map +1 -0
- package/dist/interface-adapters/presenters/jobStatus.presenter.js +57 -0
- package/dist/interface-adapters/presenters/jobStatus.presenter.js.map +1 -0
- package/dist/interface-adapters/presenters/reviewContextProgress.presenter.d.ts +8 -0
- package/dist/interface-adapters/presenters/reviewContextProgress.presenter.d.ts.map +1 -0
- package/dist/interface-adapters/presenters/reviewContextProgress.presenter.js +45 -0
- package/dist/interface-adapters/presenters/reviewContextProgress.presenter.js.map +1 -0
- package/dist/interface-adapters/presenters/reviewList.presenter.d.ts +22 -0
- package/dist/interface-adapters/presenters/reviewList.presenter.d.ts.map +1 -0
- package/dist/interface-adapters/presenters/reviewList.presenter.js +32 -0
- package/dist/interface-adapters/presenters/reviewList.presenter.js.map +1 -0
- package/dist/interface-adapters/services/projectStats.calculator.d.ts +8 -0
- package/dist/interface-adapters/services/projectStats.calculator.d.ts.map +1 -0
- package/dist/interface-adapters/services/projectStats.calculator.js +52 -0
- package/dist/interface-adapters/services/projectStats.calculator.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/index.html +1537 -0
- package/dist/interface-adapters/views/dashboard/styles.css +1127 -0
- package/dist/main/cli.d.ts +12 -0
- package/dist/main/cli.d.ts.map +1 -0
- package/dist/main/cli.js +67 -0
- package/dist/main/cli.js.map +1 -0
- package/dist/main/dependencies.d.ts +20 -0
- package/dist/main/dependencies.d.ts.map +1 -0
- package/dist/main/dependencies.js +28 -0
- package/dist/main/dependencies.js.map +1 -0
- package/dist/main/mcpDependencies.d.ts +16 -0
- package/dist/main/mcpDependencies.d.ts.map +1 -0
- package/dist/main/mcpDependencies.js +35 -0
- package/dist/main/mcpDependencies.js.map +1 -0
- package/dist/main/routes.d.ts +4 -0
- package/dist/main/routes.d.ts.map +1 -0
- package/dist/main/routes.js +74 -0
- package/dist/main/routes.js.map +1 -0
- package/dist/main/server.d.ts +8 -0
- package/dist/main/server.d.ts.map +1 -0
- package/dist/main/server.js +54 -0
- package/dist/main/server.js.map +1 -0
- package/dist/main/websocket.d.ts +10 -0
- package/dist/main/websocket.d.ts.map +1 -0
- package/dist/main/websocket.js +109 -0
- package/dist/main/websocket.js.map +1 -0
- package/dist/mcp/mcpLogger.d.ts +9 -0
- package/dist/mcp/mcpLogger.d.ts.map +1 -0
- package/dist/mcp/mcpLogger.js +49 -0
- package/dist/mcp/mcpLogger.js.map +1 -0
- package/dist/mcp/mcpServerStdio.d.ts +13 -0
- package/dist/mcp/mcpServerStdio.d.ts.map +1 -0
- package/dist/mcp/mcpServerStdio.js +239 -0
- package/dist/mcp/mcpServerStdio.js.map +1 -0
- package/dist/mcp/server.d.ts +8 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +24 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/types.d.ts +27 -0
- package/dist/mcp/types.d.ts.map +1 -0
- package/dist/mcp/types.js +2 -0
- package/dist/mcp/types.js.map +1 -0
- package/dist/mcpServer.d.ts +2 -0
- package/dist/mcpServer.d.ts.map +1 -0
- package/dist/mcpServer.js +16 -0
- package/dist/mcpServer.js.map +1 -0
- package/dist/queue/reviewQueue.d.ts +3 -0
- package/dist/queue/reviewQueue.d.ts.map +1 -0
- package/dist/queue/reviewQueue.js +4 -0
- package/dist/queue/reviewQueue.js.map +1 -0
- package/dist/security/verifier.d.ts +21 -0
- package/dist/security/verifier.d.ts.map +1 -0
- package/dist/security/verifier.js +67 -0
- package/dist/security/verifier.js.map +1 -0
- package/dist/server.d.ts +2 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +6 -0
- package/dist/server.js.map +1 -0
- package/dist/services/agentInstructionsBuilder.d.ts +4 -0
- package/dist/services/agentInstructionsBuilder.d.ts.map +1 -0
- package/dist/services/agentInstructionsBuilder.js +65 -0
- package/dist/services/agentInstructionsBuilder.js.map +1 -0
- package/dist/services/contextActionsExecutor.d.ts +19 -0
- package/dist/services/contextActionsExecutor.d.ts.map +1 -0
- package/dist/services/contextActionsExecutor.js +18 -0
- package/dist/services/contextActionsExecutor.js.map +1 -0
- package/dist/services/logService.d.ts +3 -0
- package/dist/services/logService.d.ts.map +1 -0
- package/dist/services/logService.js +4 -0
- package/dist/services/logService.js.map +1 -0
- package/dist/services/mrTrackingService.d.ts +196 -0
- package/dist/services/mrTrackingService.d.ts.map +1 -0
- package/dist/services/mrTrackingService.js +540 -0
- package/dist/services/mrTrackingService.js.map +1 -0
- package/dist/services/reviewContextWatcher.service.d.ts +15 -0
- package/dist/services/reviewContextWatcher.service.d.ts.map +1 -0
- package/dist/services/reviewContextWatcher.service.js +44 -0
- package/dist/services/reviewContextWatcher.service.js.map +1 -0
- package/dist/services/runtimeSettings.d.ts +3 -0
- package/dist/services/runtimeSettings.d.ts.map +1 -0
- package/dist/services/runtimeSettings.js +4 -0
- package/dist/services/runtimeSettings.js.map +1 -0
- package/dist/services/statsService.d.ts +76 -0
- package/dist/services/statsService.d.ts.map +1 -0
- package/dist/services/statsService.js +250 -0
- package/dist/services/statsService.js.map +1 -0
- package/dist/services/threadActionsExecutor.d.ts +26 -0
- package/dist/services/threadActionsExecutor.d.ts.map +1 -0
- package/dist/services/threadActionsExecutor.js +27 -0
- package/dist/services/threadActionsExecutor.js.map +1 -0
- package/dist/services/threadActionsParser.d.ts +4 -0
- package/dist/services/threadActionsParser.d.ts.map +1 -0
- package/dist/services/threadActionsParser.js +50 -0
- package/dist/services/threadActionsParser.js.map +1 -0
- package/dist/shared/foundation/executionGateway.base.d.ts +14 -0
- package/dist/shared/foundation/executionGateway.base.d.ts.map +1 -0
- package/dist/shared/foundation/executionGateway.base.js +30 -0
- package/dist/shared/foundation/executionGateway.base.js.map +1 -0
- package/dist/shared/foundation/gateway.base.d.ts +9 -0
- package/dist/shared/foundation/gateway.base.d.ts.map +1 -0
- package/dist/shared/foundation/gateway.base.js +2 -0
- package/dist/shared/foundation/gateway.base.js.map +1 -0
- package/dist/shared/foundation/guard.base.d.ts +8 -0
- package/dist/shared/foundation/guard.base.d.ts.map +1 -0
- package/dist/shared/foundation/guard.base.js +17 -0
- package/dist/shared/foundation/guard.base.js.map +1 -0
- package/dist/shared/foundation/presenter.base.d.ts +4 -0
- package/dist/shared/foundation/presenter.base.d.ts.map +1 -0
- package/dist/shared/foundation/presenter.base.js +2 -0
- package/dist/shared/foundation/presenter.base.js.map +1 -0
- package/dist/shared/foundation/usecase.base.d.ts +4 -0
- package/dist/shared/foundation/usecase.base.d.ts.map +1 -0
- package/dist/shared/foundation/usecase.base.js +2 -0
- package/dist/shared/foundation/usecase.base.js.map +1 -0
- package/dist/shared/services/claudePathResolver.d.ts +3 -0
- package/dist/shared/services/claudePathResolver.d.ts.map +1 -0
- package/dist/shared/services/claudePathResolver.js +62 -0
- package/dist/shared/services/claudePathResolver.js.map +1 -0
- package/dist/shared/services/dependencyChecker.d.ts +13 -0
- package/dist/shared/services/dependencyChecker.d.ts.map +1 -0
- package/dist/shared/services/dependencyChecker.js +37 -0
- package/dist/shared/services/dependencyChecker.js.map +1 -0
- package/dist/shared/services/mcpJobContext.d.ts +3 -0
- package/dist/shared/services/mcpJobContext.d.ts.map +1 -0
- package/dist/shared/services/mcpJobContext.js +10 -0
- package/dist/shared/services/mcpJobContext.js.map +1 -0
- package/dist/tests/factories/config.factory.d.ts +4 -0
- package/dist/tests/factories/config.factory.d.ts.map +1 -0
- package/dist/tests/factories/config.factory.js +27 -0
- package/dist/tests/factories/config.factory.js.map +1 -0
- package/dist/tests/factories/gitHubEvent.factory.d.ts +14 -0
- package/dist/tests/factories/gitHubEvent.factory.d.ts.map +1 -0
- package/dist/tests/factories/gitHubEvent.factory.js +93 -0
- package/dist/tests/factories/gitHubEvent.factory.js.map +1 -0
- package/dist/tests/factories/gitLabEvent.factory.d.ts +18 -0
- package/dist/tests/factories/gitLabEvent.factory.d.ts.map +1 -0
- package/dist/tests/factories/gitLabEvent.factory.js +129 -0
- package/dist/tests/factories/gitLabEvent.factory.js.map +1 -0
- package/dist/tests/factories/githubApiResponse.factory.d.ts +21 -0
- package/dist/tests/factories/githubApiResponse.factory.d.ts.map +1 -0
- package/dist/tests/factories/githubApiResponse.factory.js +25 -0
- package/dist/tests/factories/githubApiResponse.factory.js.map +1 -0
- package/dist/tests/factories/gitlabApiResponse.factory.d.ts +26 -0
- package/dist/tests/factories/gitlabApiResponse.factory.d.ts.map +1 -0
- package/dist/tests/factories/gitlabApiResponse.factory.js +9 -0
- package/dist/tests/factories/gitlabApiResponse.factory.js.map +1 -0
- package/dist/tests/factories/projectStats.factory.d.ts +9 -0
- package/dist/tests/factories/projectStats.factory.d.ts.map +1 -0
- package/dist/tests/factories/projectStats.factory.js +48 -0
- package/dist/tests/factories/projectStats.factory.js.map +1 -0
- package/dist/tests/factories/reviewContext.factory.d.ts +9 -0
- package/dist/tests/factories/reviewContext.factory.d.ts.map +1 -0
- package/dist/tests/factories/reviewContext.factory.js +59 -0
- package/dist/tests/factories/reviewContext.factory.js.map +1 -0
- package/dist/tests/factories/reviewJob.factory.d.ts +10 -0
- package/dist/tests/factories/reviewJob.factory.d.ts.map +1 -0
- package/dist/tests/factories/reviewJob.factory.js +43 -0
- package/dist/tests/factories/reviewJob.factory.js.map +1 -0
- package/dist/tests/factories/trackedMr.factory.d.ts +10 -0
- package/dist/tests/factories/trackedMr.factory.d.ts.map +1 -0
- package/dist/tests/factories/trackedMr.factory.js +65 -0
- package/dist/tests/factories/trackedMr.factory.js.map +1 -0
- package/dist/tests/factories/webhookEvent.factory.d.ts +8 -0
- package/dist/tests/factories/webhookEvent.factory.d.ts.map +1 -0
- package/dist/tests/factories/webhookEvent.factory.js +72 -0
- package/dist/tests/factories/webhookEvent.factory.js.map +1 -0
- package/dist/tests/integration/server.integration.test.d.ts +2 -0
- package/dist/tests/integration/server.integration.test.d.ts.map +1 -0
- package/dist/tests/integration/server.integration.test.js +93 -0
- package/dist/tests/integration/server.integration.test.js.map +1 -0
- package/dist/tests/stubs/fastifyRequest.stub.d.ts +9 -0
- package/dist/tests/stubs/fastifyRequest.stub.d.ts.map +1 -0
- package/dist/tests/stubs/fastifyRequest.stub.js +11 -0
- package/dist/tests/stubs/fastifyRequest.stub.js.map +1 -0
- package/dist/tests/stubs/logger.stub.d.ts +3 -0
- package/dist/tests/stubs/logger.stub.d.ts.map +1 -0
- package/dist/tests/stubs/logger.stub.js +14 -0
- package/dist/tests/stubs/logger.stub.js.map +1 -0
- package/dist/tests/stubs/reviewContextGateway.stub.d.ts +18 -0
- package/dist/tests/stubs/reviewContextGateway.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewContextGateway.stub.js +69 -0
- package/dist/tests/stubs/reviewContextGateway.stub.js.map +1 -0
- package/dist/tests/stubs/reviewFile.stub.d.ts +13 -0
- package/dist/tests/stubs/reviewFile.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewFile.stub.js +56 -0
- package/dist/tests/stubs/reviewFile.stub.js.map +1 -0
- package/dist/tests/stubs/reviewQueue.stub.d.ts +20 -0
- package/dist/tests/stubs/reviewQueue.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewQueue.stub.js +46 -0
- package/dist/tests/stubs/reviewQueue.stub.js.map +1 -0
- package/dist/tests/stubs/reviewRequestTracking.stub.d.ts +21 -0
- package/dist/tests/stubs/reviewRequestTracking.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewRequestTracking.stub.js +121 -0
- package/dist/tests/stubs/reviewRequestTracking.stub.js.map +1 -0
- package/dist/tests/stubs/stats.stub.d.ts +10 -0
- package/dist/tests/stubs/stats.stub.d.ts.map +1 -0
- package/dist/tests/stubs/stats.stub.js +17 -0
- package/dist/tests/stubs/stats.stub.js.map +1 -0
- package/dist/tests/stubs/threadFetch.stub.d.ts +8 -0
- package/dist/tests/stubs/threadFetch.stub.d.ts.map +1 -0
- package/dist/tests/stubs/threadFetch.stub.js +10 -0
- package/dist/tests/stubs/threadFetch.stub.js.map +1 -0
- package/dist/tests/units/claude/progressParser.test.d.ts +2 -0
- package/dist/tests/units/claude/progressParser.test.d.ts.map +1 -0
- package/dist/tests/units/claude/progressParser.test.js +202 -0
- package/dist/tests/units/claude/progressParser.test.js.map +1 -0
- package/dist/tests/units/cli/cli.integration.test.d.ts +2 -0
- package/dist/tests/units/cli/cli.integration.test.d.ts.map +1 -0
- package/dist/tests/units/cli/cli.integration.test.js +18 -0
- package/dist/tests/units/cli/cli.integration.test.js.map +1 -0
- package/dist/tests/units/cli/parseCliArgs.test.d.ts +2 -0
- package/dist/tests/units/cli/parseCliArgs.test.d.ts.map +1 -0
- package/dist/tests/units/cli/parseCliArgs.test.js +35 -0
- package/dist/tests/units/cli/parseCliArgs.test.js.map +1 -0
- package/dist/tests/units/entities/duration.valueObject.test.d.ts +2 -0
- package/dist/tests/units/entities/duration.valueObject.test.d.ts.map +1 -0
- package/dist/tests/units/entities/duration.valueObject.test.js +112 -0
- package/dist/tests/units/entities/duration.valueObject.test.js.map +1 -0
- package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.d.ts +2 -0
- package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.d.ts.map +1 -0
- package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.js +53 -0
- package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.js.map +1 -0
- package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.d.ts +2 -0
- package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.d.ts.map +1 -0
- package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.js +97 -0
- package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.js.map +1 -0
- package/dist/tests/units/entities/progress/progress.test.d.ts +2 -0
- package/dist/tests/units/entities/progress/progress.test.d.ts.map +1 -0
- package/dist/tests/units/entities/progress/progress.test.js +137 -0
- package/dist/tests/units/entities/progress/progress.test.js.map +1 -0
- package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.d.ts +2 -0
- package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.d.ts.map +1 -0
- package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.js +89 -0
- package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.js.map +1 -0
- package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.js +176 -0
- package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.js.map +1 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.d.ts +2 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.d.ts.map +1 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.js +88 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.js.map +1 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.js +132 -0
- package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.js.map +1 -0
- package/dist/tests/units/entities/reviewRequestState.valueObject.test.d.ts +2 -0
- package/dist/tests/units/entities/reviewRequestState.valueObject.test.d.ts.map +1 -0
- package/dist/tests/units/entities/reviewRequestState.valueObject.test.js +100 -0
- package/dist/tests/units/entities/reviewRequestState.valueObject.test.js.map +1 -0
- package/dist/tests/units/entities/reviewScore.valueObject.test.d.ts +2 -0
- package/dist/tests/units/entities/reviewScore.valueObject.test.d.ts.map +1 -0
- package/dist/tests/units/entities/reviewScore.valueObject.test.js +90 -0
- package/dist/tests/units/entities/reviewScore.valueObject.test.js.map +1 -0
- package/dist/tests/units/factories/factories.test.d.ts +2 -0
- package/dist/tests/units/factories/factories.test.d.ts.map +1 -0
- package/dist/tests/units/factories/factories.test.js +100 -0
- package/dist/tests/units/factories/factories.test.js.map +1 -0
- package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.d.ts +2 -0
- package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.js +88 -0
- package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.js.map +1 -0
- package/dist/tests/units/frameworks/claude/mcpContext.test.d.ts +2 -0
- package/dist/tests/units/frameworks/claude/mcpContext.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/claude/mcpContext.test.js +88 -0
- package/dist/tests/units/frameworks/claude/mcpContext.test.js.map +1 -0
- package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.d.ts +2 -0
- package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.js +20 -0
- package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.js +181 -0
- package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.js +84 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.js +71 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.js +52 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.js +32 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.js +44 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.js +38 -0
- package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.js +389 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js +284 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +202 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.js +83 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.js +92 -0
- package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.js +41 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.js +57 -0
- package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.js +204 -0
- package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.js +126 -0
- package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.js +137 -0
- package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js +242 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.js +52 -0
- package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.js +41 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.js +31 -0
- package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.js +128 -0
- package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.js +83 -0
- package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.js +64 -0
- package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.js +85 -0
- package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.js.map +1 -0
- package/dist/tests/units/main/dependencies.test.d.ts +2 -0
- package/dist/tests/units/main/dependencies.test.d.ts.map +1 -0
- package/dist/tests/units/main/dependencies.test.js +43 -0
- package/dist/tests/units/main/dependencies.test.js.map +1 -0
- package/dist/tests/units/main/executeStart.test.d.ts +2 -0
- package/dist/tests/units/main/executeStart.test.d.ts.map +1 -0
- package/dist/tests/units/main/executeStart.test.js +61 -0
- package/dist/tests/units/main/executeStart.test.js.map +1 -0
- package/dist/tests/units/main/mcpDependencies.test.d.ts +2 -0
- package/dist/tests/units/main/mcpDependencies.test.d.ts.map +1 -0
- package/dist/tests/units/main/mcpDependencies.test.js +56 -0
- package/dist/tests/units/main/mcpDependencies.test.js.map +1 -0
- package/dist/tests/units/main/websocket.test.d.ts +2 -0
- package/dist/tests/units/main/websocket.test.d.ts.map +1 -0
- package/dist/tests/units/main/websocket.test.js +63 -0
- package/dist/tests/units/main/websocket.test.js.map +1 -0
- package/dist/tests/units/mcp/mcpServerStdio.test.d.ts +2 -0
- package/dist/tests/units/mcp/mcpServerStdio.test.d.ts.map +1 -0
- package/dist/tests/units/mcp/mcpServerStdio.test.js +179 -0
- package/dist/tests/units/mcp/mcpServerStdio.test.js.map +1 -0
- package/dist/tests/units/mcp/server.test.d.ts +2 -0
- package/dist/tests/units/mcp/server.test.d.ts.map +1 -0
- package/dist/tests/units/mcp/server.test.js +85 -0
- package/dist/tests/units/mcp/server.test.js.map +1 -0
- package/dist/tests/units/security/verifier.test.d.ts +2 -0
- package/dist/tests/units/security/verifier.test.d.ts.map +1 -0
- package/dist/tests/units/security/verifier.test.js +200 -0
- package/dist/tests/units/security/verifier.test.js.map +1 -0
- package/dist/tests/units/services/contextActionsExecutor.test.d.ts +2 -0
- package/dist/tests/units/services/contextActionsExecutor.test.d.ts.map +1 -0
- package/dist/tests/units/services/contextActionsExecutor.test.js +112 -0
- package/dist/tests/units/services/contextActionsExecutor.test.js.map +1 -0
- package/dist/tests/units/services/mrTrackingRemoveMr.test.d.ts +2 -0
- package/dist/tests/units/services/mrTrackingRemoveMr.test.d.ts.map +1 -0
- package/dist/tests/units/services/mrTrackingRemoveMr.test.js +155 -0
- package/dist/tests/units/services/mrTrackingRemoveMr.test.js.map +1 -0
- package/dist/tests/units/services/mrTrackingService.autoFollowup.test.d.ts +2 -0
- package/dist/tests/units/services/mrTrackingService.autoFollowup.test.d.ts.map +1 -0
- package/dist/tests/units/services/mrTrackingService.autoFollowup.test.js +82 -0
- package/dist/tests/units/services/mrTrackingService.autoFollowup.test.js.map +1 -0
- package/dist/tests/units/services/reviewContextWatcher.service.test.d.ts +2 -0
- package/dist/tests/units/services/reviewContextWatcher.service.test.d.ts.map +1 -0
- package/dist/tests/units/services/reviewContextWatcher.service.test.js +112 -0
- package/dist/tests/units/services/reviewContextWatcher.service.test.js.map +1 -0
- package/dist/tests/units/services/threadActionsExecutor.test.d.ts +2 -0
- package/dist/tests/units/services/threadActionsExecutor.test.d.ts.map +1 -0
- package/dist/tests/units/services/threadActionsExecutor.test.js +206 -0
- package/dist/tests/units/services/threadActionsExecutor.test.js.map +1 -0
- package/dist/tests/units/services/threadActionsParser.test.d.ts +2 -0
- package/dist/tests/units/services/threadActionsParser.test.d.ts.map +1 -0
- package/dist/tests/units/services/threadActionsParser.test.js +148 -0
- package/dist/tests/units/services/threadActionsParser.test.js.map +1 -0
- package/dist/tests/units/shared/foundation/foundation.contracts.test.d.ts +2 -0
- package/dist/tests/units/shared/foundation/foundation.contracts.test.d.ts.map +1 -0
- package/dist/tests/units/shared/foundation/foundation.contracts.test.js +46 -0
- package/dist/tests/units/shared/foundation/foundation.contracts.test.js.map +1 -0
- package/dist/tests/units/shared/foundation/guard.base.test.d.ts +2 -0
- package/dist/tests/units/shared/foundation/guard.base.test.d.ts.map +1 -0
- package/dist/tests/units/shared/foundation/guard.base.test.js +40 -0
- package/dist/tests/units/shared/foundation/guard.base.test.js.map +1 -0
- package/dist/tests/units/shared/services/claudePathResolver.test.d.ts +2 -0
- package/dist/tests/units/shared/services/claudePathResolver.test.d.ts.map +1 -0
- package/dist/tests/units/shared/services/claudePathResolver.test.js +61 -0
- package/dist/tests/units/shared/services/claudePathResolver.test.js.map +1 -0
- package/dist/tests/units/shared/services/dependencyChecker.test.d.ts +2 -0
- package/dist/tests/units/shared/services/dependencyChecker.test.d.ts.map +1 -0
- package/dist/tests/units/shared/services/dependencyChecker.test.js +35 -0
- package/dist/tests/units/shared/services/dependencyChecker.test.js.map +1 -0
- package/dist/tests/units/shared/services/mcpJobContext.test.d.ts +2 -0
- package/dist/tests/units/shared/services/mcpJobContext.test.d.ts.map +1 -0
- package/dist/tests/units/shared/services/mcpJobContext.test.js +38 -0
- package/dist/tests/units/shared/services/mcpJobContext.test.js.map +1 -0
- package/dist/tests/units/types/progress.test.d.ts +2 -0
- package/dist/tests/units/types/progress.test.d.ts.map +1 -0
- package/dist/tests/units/types/progress.test.js +135 -0
- package/dist/tests/units/types/progress.test.js.map +1 -0
- package/dist/tests/units/usecases/cancelReview.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/cancelReview.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/cancelReview.usecase.test.js +57 -0
- package/dist/tests/units/usecases/cancelReview.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.js +124 -0
- package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/addAction.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/mcp/addAction.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/mcp/addAction.usecase.test.js +123 -0
- package/dist/tests/units/usecases/mcp/addAction.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.js +67 -0
- package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/getThreads.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/mcp/getThreads.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/mcp/getThreads.usecase.test.js +77 -0
- package/dist/tests/units/usecases/mcp/getThreads.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.js +55 -0
- package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js +41 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/startAgent.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/mcp/startAgent.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/mcp/startAgent.usecase.test.js +42 -0
- package/dist/tests/units/usecases/mcp/startAgent.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.js +71 -0
- package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/recordPush.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/tracking/recordPush.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/tracking/recordPush.usecase.test.js +22 -0
- package/dist/tests/units/usecases/tracking/recordPush.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js +106 -0
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.js +76 -0
- package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.js +70 -0
- package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/transitionState.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/tracking/transitionState.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/tracking/transitionState.usecase.test.js +48 -0
- package/dist/tests/units/usecases/tracking/transitionState.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/triggerReview.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/triggerReview.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/triggerReview.usecase.test.js +103 -0
- package/dist/tests/units/usecases/triggerReview.usecase.test.js.map +1 -0
- package/dist/types/progress.d.ts +55 -0
- package/dist/types/progress.d.ts.map +1 -0
- package/dist/types/progress.js +63 -0
- package/dist/types/progress.js.map +1 -0
- package/dist/usecases/cancelReview.usecase.d.ts +21 -0
- package/dist/usecases/cancelReview.usecase.d.ts.map +1 -0
- package/dist/usecases/cancelReview.usecase.js +19 -0
- package/dist/usecases/cancelReview.usecase.js.map +1 -0
- package/dist/usecases/handleReviewRequestPush.usecase.d.ts +26 -0
- package/dist/usecases/handleReviewRequestPush.usecase.d.ts.map +1 -0
- package/dist/usecases/handleReviewRequestPush.usecase.js +45 -0
- package/dist/usecases/handleReviewRequestPush.usecase.js.map +1 -0
- package/dist/usecases/mcp/addAction.usecase.d.ts +33 -0
- package/dist/usecases/mcp/addAction.usecase.d.ts.map +1 -0
- package/dist/usecases/mcp/addAction.usecase.js +94 -0
- package/dist/usecases/mcp/addAction.usecase.js.map +1 -0
- package/dist/usecases/mcp/completeAgent.usecase.d.ts +18 -0
- package/dist/usecases/mcp/completeAgent.usecase.d.ts.map +1 -0
- package/dist/usecases/mcp/completeAgent.usecase.js +20 -0
- package/dist/usecases/mcp/completeAgent.usecase.js.map +1 -0
- package/dist/usecases/mcp/getThreads.usecase.d.ts +16 -0
- package/dist/usecases/mcp/getThreads.usecase.d.ts.map +1 -0
- package/dist/usecases/mcp/getThreads.usecase.js +22 -0
- package/dist/usecases/mcp/getThreads.usecase.js.map +1 -0
- package/dist/usecases/mcp/getWorkflow.usecase.d.ts +28 -0
- package/dist/usecases/mcp/getWorkflow.usecase.d.ts.map +1 -0
- package/dist/usecases/mcp/getWorkflow.usecase.js +36 -0
- package/dist/usecases/mcp/getWorkflow.usecase.js.map +1 -0
- package/dist/usecases/mcp/setPhase.usecase.d.ts +15 -0
- package/dist/usecases/mcp/setPhase.usecase.d.ts.map +1 -0
- package/dist/usecases/mcp/setPhase.usecase.js +16 -0
- package/dist/usecases/mcp/setPhase.usecase.js.map +1 -0
- package/dist/usecases/mcp/startAgent.usecase.d.ts +15 -0
- package/dist/usecases/mcp/startAgent.usecase.d.ts.map +1 -0
- package/dist/usecases/mcp/startAgent.usecase.js +18 -0
- package/dist/usecases/mcp/startAgent.usecase.js.map +1 -0
- package/dist/usecases/tracking/checkFollowupNeeded.usecase.d.ts +14 -0
- package/dist/usecases/tracking/checkFollowupNeeded.usecase.d.ts.map +1 -0
- package/dist/usecases/tracking/checkFollowupNeeded.usecase.js +17 -0
- package/dist/usecases/tracking/checkFollowupNeeded.usecase.js.map +1 -0
- package/dist/usecases/tracking/recordPush.usecase.d.ts +15 -0
- package/dist/usecases/tracking/recordPush.usecase.d.ts.map +1 -0
- package/dist/usecases/tracking/recordPush.usecase.js +10 -0
- package/dist/usecases/tracking/recordPush.usecase.js.map +1 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts +24 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts.map +1 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.js +52 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.js.map +1 -0
- package/dist/usecases/tracking/syncThreads.usecase.d.ts +16 -0
- package/dist/usecases/tracking/syncThreads.usecase.d.ts.map +1 -0
- package/dist/usecases/tracking/syncThreads.usecase.js +26 -0
- package/dist/usecases/tracking/syncThreads.usecase.js.map +1 -0
- package/dist/usecases/tracking/trackAssignment.usecase.d.ts +28 -0
- package/dist/usecases/tracking/trackAssignment.usecase.d.ts.map +1 -0
- package/dist/usecases/tracking/trackAssignment.usecase.js +69 -0
- package/dist/usecases/tracking/trackAssignment.usecase.js.map +1 -0
- package/dist/usecases/tracking/transitionState.usecase.d.ts +14 -0
- package/dist/usecases/tracking/transitionState.usecase.d.ts.map +1 -0
- package/dist/usecases/tracking/transitionState.usecase.js +22 -0
- package/dist/usecases/tracking/transitionState.usecase.js.map +1 -0
- package/dist/usecases/triggerReview.usecase.d.ts +41 -0
- package/dist/usecases/triggerReview.usecase.d.ts.map +1 -0
- package/dist/usecases/triggerReview.usecase.js +34 -0
- package/dist/usecases/triggerReview.usecase.js.map +1 -0
- package/package.json +82 -0
- package/scripts/copyAssets.mjs +10 -0
- package/scripts/launcher.sh +35 -0
- package/templates/SETUP.md +183 -0
- package/templates/SKILL.md.template +207 -0
- package/templates/claude-mcp-config.example.json +12 -0
- package/templates/config.json.template +15 -0
- package/templates/en/followup-basic/README.md +66 -0
- package/templates/en/followup-basic/SKILL.md +317 -0
- package/templates/en/review-basic/README.md +75 -0
- package/templates/en/review-basic/SKILL.md +160 -0
- package/templates/en/review-with-agents/README.md +78 -0
- package/templates/en/review-with-agents/SKILL.md +225 -0
- package/templates/fr/followup-basic/README.md +66 -0
- package/templates/fr/followup-basic/SKILL.md +317 -0
- package/templates/fr/review-basic/README.md +59 -0
- package/templates/fr/review-basic/SKILL.md +160 -0
- package/templates/fr/review-with-agents/README.md +54 -0
- package/templates/fr/review-with-agents/SKILL.md +225 -0
- package/templates/skills/review-bootstrap/SKILL.md +119 -0
- package/templates/skills/review-with-mcp.md +133 -0
|
@@ -0,0 +1,540 @@
|
|
|
1
|
+
import { readFileSync, writeFileSync, existsSync, mkdirSync } from 'node:fs';
|
|
2
|
+
import { join, dirname } from 'node:path';
|
|
3
|
+
import { execSync } from 'node:child_process';
|
|
4
|
+
function getTrackingPath(projectPath) {
|
|
5
|
+
return join(projectPath, '.claude', 'reviews', 'mr-tracking.json');
|
|
6
|
+
}
|
|
7
|
+
function createEmptyStats() {
|
|
8
|
+
return {
|
|
9
|
+
totalMrs: 0,
|
|
10
|
+
totalReviews: 0,
|
|
11
|
+
totalFollowups: 0,
|
|
12
|
+
averageReviewsPerMr: 0,
|
|
13
|
+
averageTimeToApproval: null,
|
|
14
|
+
topAssigners: [],
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
function recalculateStats(data) {
|
|
18
|
+
const mrs = data.mrs;
|
|
19
|
+
data.stats.totalMrs = mrs.length;
|
|
20
|
+
data.stats.totalReviews = mrs.reduce((sum, mr) => sum + mr.totalReviews, 0);
|
|
21
|
+
data.stats.totalFollowups = mrs.reduce((sum, mr) => sum + mr.totalFollowups, 0);
|
|
22
|
+
if (mrs.length > 0) {
|
|
23
|
+
data.stats.averageReviewsPerMr = (data.stats.totalReviews + data.stats.totalFollowups) / mrs.length;
|
|
24
|
+
}
|
|
25
|
+
// Calculate average time to approval
|
|
26
|
+
const approvedMrs = mrs.filter((mr) => mr.approvedAt && mr.createdAt);
|
|
27
|
+
if (approvedMrs.length > 0) {
|
|
28
|
+
const totalTime = approvedMrs.reduce((sum, mr) => {
|
|
29
|
+
const created = new Date(mr.createdAt).getTime();
|
|
30
|
+
const approved = new Date(mr.approvedAt).getTime();
|
|
31
|
+
return sum + (approved - created);
|
|
32
|
+
}, 0);
|
|
33
|
+
data.stats.averageTimeToApproval = totalTime / approvedMrs.length;
|
|
34
|
+
}
|
|
35
|
+
// Top assigners
|
|
36
|
+
const assignerCounts = new Map();
|
|
37
|
+
for (const mr of mrs) {
|
|
38
|
+
const username = mr.assignment.username;
|
|
39
|
+
assignerCounts.set(username, (assignerCounts.get(username) || 0) + 1);
|
|
40
|
+
}
|
|
41
|
+
data.stats.topAssigners = Array.from(assignerCounts.entries())
|
|
42
|
+
.map(([username, count]) => ({ username, count }))
|
|
43
|
+
.sort((a, b) => b.count - a.count)
|
|
44
|
+
.slice(0, 10);
|
|
45
|
+
}
|
|
46
|
+
export function loadMrTracking(projectPath) {
|
|
47
|
+
const trackingPath = getTrackingPath(projectPath);
|
|
48
|
+
if (!existsSync(trackingPath)) {
|
|
49
|
+
return { mrs: [], lastUpdated: new Date().toISOString(), stats: createEmptyStats() };
|
|
50
|
+
}
|
|
51
|
+
try {
|
|
52
|
+
const content = readFileSync(trackingPath, 'utf-8');
|
|
53
|
+
const data = JSON.parse(content);
|
|
54
|
+
// Ensure arrays and stats exist
|
|
55
|
+
if (!Array.isArray(data.mrs)) {
|
|
56
|
+
data.mrs = [];
|
|
57
|
+
}
|
|
58
|
+
if (!data.stats) {
|
|
59
|
+
data.stats = createEmptyStats();
|
|
60
|
+
}
|
|
61
|
+
for (const mr of data.mrs) {
|
|
62
|
+
if (mr.autoFollowup === undefined) {
|
|
63
|
+
mr.autoFollowup = true;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return data;
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
return { mrs: [], lastUpdated: new Date().toISOString(), stats: createEmptyStats() };
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
export function saveMrTracking(projectPath, data) {
|
|
73
|
+
const trackingPath = getTrackingPath(projectPath);
|
|
74
|
+
const dir = dirname(trackingPath);
|
|
75
|
+
if (!existsSync(dir)) {
|
|
76
|
+
mkdirSync(dir, { recursive: true });
|
|
77
|
+
}
|
|
78
|
+
// Recalculate stats before saving
|
|
79
|
+
recalculateStats(data);
|
|
80
|
+
data.lastUpdated = new Date().toISOString();
|
|
81
|
+
writeFileSync(trackingPath, JSON.stringify(data, null, 2), 'utf-8');
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Create or update a tracked MR when assigned for review
|
|
85
|
+
*/
|
|
86
|
+
export function trackMrAssignment(projectPath, mrInfo, assignedBy) {
|
|
87
|
+
const data = loadMrTracking(projectPath);
|
|
88
|
+
const mrId = `${mrInfo.platform}-${mrInfo.project}-${mrInfo.mrNumber}`;
|
|
89
|
+
const existingIndex = data.mrs.findIndex((mr) => mr.id === mrId);
|
|
90
|
+
if (existingIndex >= 0) {
|
|
91
|
+
// MR already tracked, update assignment info but KEEP existing state
|
|
92
|
+
// Don't reset state - the MR might be in pending-fix waiting for followup
|
|
93
|
+
const existing = data.mrs[existingIndex];
|
|
94
|
+
existing.title = mrInfo.title;
|
|
95
|
+
existing.assignment = {
|
|
96
|
+
username: assignedBy.username,
|
|
97
|
+
displayName: assignedBy.displayName,
|
|
98
|
+
assignedAt: new Date().toISOString(),
|
|
99
|
+
};
|
|
100
|
+
// Only set to pending-review if it's a new MR or was merged/closed
|
|
101
|
+
if (['merged', 'closed'].includes(existing.state)) {
|
|
102
|
+
existing.state = 'pending-review';
|
|
103
|
+
}
|
|
104
|
+
saveMrTracking(projectPath, data);
|
|
105
|
+
return existing;
|
|
106
|
+
}
|
|
107
|
+
// Create new tracked MR
|
|
108
|
+
const now = new Date().toISOString();
|
|
109
|
+
const trackedMr = {
|
|
110
|
+
id: mrId,
|
|
111
|
+
mrNumber: mrInfo.mrNumber,
|
|
112
|
+
title: mrInfo.title,
|
|
113
|
+
url: mrInfo.url,
|
|
114
|
+
project: mrInfo.project,
|
|
115
|
+
platform: mrInfo.platform,
|
|
116
|
+
sourceBranch: mrInfo.sourceBranch,
|
|
117
|
+
targetBranch: mrInfo.targetBranch,
|
|
118
|
+
assignment: {
|
|
119
|
+
username: assignedBy.username,
|
|
120
|
+
displayName: assignedBy.displayName,
|
|
121
|
+
assignedAt: now,
|
|
122
|
+
},
|
|
123
|
+
state: 'pending-review',
|
|
124
|
+
openThreads: 0,
|
|
125
|
+
totalThreads: 0,
|
|
126
|
+
createdAt: now,
|
|
127
|
+
lastReviewAt: null,
|
|
128
|
+
lastPushAt: null,
|
|
129
|
+
approvedAt: null,
|
|
130
|
+
mergedAt: null,
|
|
131
|
+
reviews: [],
|
|
132
|
+
totalReviews: 0,
|
|
133
|
+
totalFollowups: 0,
|
|
134
|
+
totalBlocking: 0,
|
|
135
|
+
totalWarnings: 0,
|
|
136
|
+
totalSuggestions: 0,
|
|
137
|
+
totalDurationMs: 0,
|
|
138
|
+
averageScore: null,
|
|
139
|
+
latestScore: null,
|
|
140
|
+
autoFollowup: true,
|
|
141
|
+
};
|
|
142
|
+
data.mrs.push(trackedMr);
|
|
143
|
+
saveMrTracking(projectPath, data);
|
|
144
|
+
return trackedMr;
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Record a review completion on a MR
|
|
148
|
+
*/
|
|
149
|
+
export function recordReviewCompletion(projectPath, mrId, reviewData) {
|
|
150
|
+
const data = loadMrTracking(projectPath);
|
|
151
|
+
const mr = data.mrs.find((m) => m.id === mrId);
|
|
152
|
+
if (!mr)
|
|
153
|
+
return undefined;
|
|
154
|
+
const now = new Date().toISOString();
|
|
155
|
+
// Add review event
|
|
156
|
+
const event = {
|
|
157
|
+
type: reviewData.type,
|
|
158
|
+
timestamp: now,
|
|
159
|
+
durationMs: reviewData.durationMs,
|
|
160
|
+
score: reviewData.score,
|
|
161
|
+
blocking: reviewData.blocking,
|
|
162
|
+
warnings: reviewData.warnings,
|
|
163
|
+
suggestions: reviewData.suggestions ?? 0,
|
|
164
|
+
threadsOpened: reviewData.threadsOpened ?? 0,
|
|
165
|
+
threadsClosed: reviewData.threadsClosed ?? 0,
|
|
166
|
+
};
|
|
167
|
+
mr.reviews.push(event);
|
|
168
|
+
// Update aggregates
|
|
169
|
+
mr.lastReviewAt = now;
|
|
170
|
+
if (reviewData.type === 'review') {
|
|
171
|
+
mr.totalReviews++;
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
mr.totalFollowups++;
|
|
175
|
+
}
|
|
176
|
+
mr.totalBlocking += reviewData.blocking;
|
|
177
|
+
mr.totalWarnings += reviewData.warnings;
|
|
178
|
+
mr.totalSuggestions += reviewData.suggestions ?? 0;
|
|
179
|
+
mr.totalDurationMs += reviewData.durationMs;
|
|
180
|
+
// Update thread counts
|
|
181
|
+
mr.openThreads = Math.max(0, mr.openThreads + (reviewData.threadsOpened ?? 0) - (reviewData.threadsClosed ?? 0));
|
|
182
|
+
mr.totalThreads += reviewData.threadsOpened ?? 0;
|
|
183
|
+
// Update latest score (current state of the MR)
|
|
184
|
+
if (reviewData.score !== null) {
|
|
185
|
+
mr.latestScore = reviewData.score;
|
|
186
|
+
}
|
|
187
|
+
// Recalculate average score (historical metric)
|
|
188
|
+
const reviewsWithScore = mr.reviews.filter((r) => r.score !== null);
|
|
189
|
+
if (reviewsWithScore.length > 0) {
|
|
190
|
+
mr.averageScore = reviewsWithScore.reduce((sum, r) => sum + (r.score ?? 0), 0) / reviewsWithScore.length;
|
|
191
|
+
}
|
|
192
|
+
// Update state based on blocking issues
|
|
193
|
+
if (reviewData.blocking > 0 || mr.openThreads > 0) {
|
|
194
|
+
mr.state = 'pending-fix';
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
mr.state = 'pending-approval';
|
|
198
|
+
}
|
|
199
|
+
saveMrTracking(projectPath, data);
|
|
200
|
+
return mr;
|
|
201
|
+
}
|
|
202
|
+
/**
|
|
203
|
+
* Record a push event on a MR
|
|
204
|
+
*/
|
|
205
|
+
export function recordMrPush(projectPath, mrNumber, platform) {
|
|
206
|
+
const data = loadMrTracking(projectPath);
|
|
207
|
+
const mr = data.mrs.find((m) => m.mrNumber === mrNumber && m.platform === platform);
|
|
208
|
+
if (!mr)
|
|
209
|
+
return undefined;
|
|
210
|
+
mr.lastPushAt = new Date().toISOString();
|
|
211
|
+
saveMrTracking(projectPath, data);
|
|
212
|
+
return mr;
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* Update thread counts for a MR (from GitLab/GitHub API)
|
|
216
|
+
*/
|
|
217
|
+
export function updateMrThreads(projectPath, mrId, openThreads, totalThreads) {
|
|
218
|
+
const data = loadMrTracking(projectPath);
|
|
219
|
+
const mr = data.mrs.find((m) => m.id === mrId);
|
|
220
|
+
if (!mr)
|
|
221
|
+
return undefined;
|
|
222
|
+
mr.openThreads = openThreads;
|
|
223
|
+
mr.totalThreads = totalThreads;
|
|
224
|
+
// Update state based on threads
|
|
225
|
+
if (openThreads > 0) {
|
|
226
|
+
mr.state = 'pending-fix';
|
|
227
|
+
}
|
|
228
|
+
else if (mr.state === 'pending-fix') {
|
|
229
|
+
mr.state = 'pending-approval';
|
|
230
|
+
}
|
|
231
|
+
saveMrTracking(projectPath, data);
|
|
232
|
+
return mr;
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Mark MR as approved
|
|
236
|
+
*/
|
|
237
|
+
export function approveMr(projectPath, mrId) {
|
|
238
|
+
const data = loadMrTracking(projectPath);
|
|
239
|
+
const mr = data.mrs.find((m) => m.id === mrId);
|
|
240
|
+
if (!mr)
|
|
241
|
+
return false;
|
|
242
|
+
mr.state = 'approved';
|
|
243
|
+
mr.approvedAt = new Date().toISOString();
|
|
244
|
+
saveMrTracking(projectPath, data);
|
|
245
|
+
return true;
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* Mark MR as merged and archive it
|
|
249
|
+
*/
|
|
250
|
+
export function markMrMerged(projectPath, mrId) {
|
|
251
|
+
const data = loadMrTracking(projectPath);
|
|
252
|
+
const mr = data.mrs.find((m) => m.id === mrId);
|
|
253
|
+
if (!mr)
|
|
254
|
+
return false;
|
|
255
|
+
mr.state = 'merged';
|
|
256
|
+
mr.mergedAt = new Date().toISOString();
|
|
257
|
+
saveMrTracking(projectPath, data);
|
|
258
|
+
return true;
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Mark MR as closed (abandoned)
|
|
262
|
+
*/
|
|
263
|
+
export function markMrClosed(projectPath, mrId) {
|
|
264
|
+
const data = loadMrTracking(projectPath);
|
|
265
|
+
const mr = data.mrs.find((m) => m.id === mrId);
|
|
266
|
+
if (!mr)
|
|
267
|
+
return false;
|
|
268
|
+
mr.state = 'closed';
|
|
269
|
+
saveMrTracking(projectPath, data);
|
|
270
|
+
return true;
|
|
271
|
+
}
|
|
272
|
+
/**
|
|
273
|
+
* Remove MR from tracking completely (no history kept)
|
|
274
|
+
*/
|
|
275
|
+
export function removeMrFromTracking(projectPath, mrId) {
|
|
276
|
+
const data = loadMrTracking(projectPath);
|
|
277
|
+
if (data.mrs.length === 0)
|
|
278
|
+
return false;
|
|
279
|
+
const index = data.mrs.findIndex((mr) => mr.id === mrId);
|
|
280
|
+
if (index < 0)
|
|
281
|
+
return false;
|
|
282
|
+
data.mrs.splice(index, 1);
|
|
283
|
+
saveMrTracking(projectPath, data);
|
|
284
|
+
return true;
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* Recompute project stats from current MR data
|
|
288
|
+
*/
|
|
289
|
+
export function recomputeProjectStats(projectPath) {
|
|
290
|
+
const data = loadMrTracking(projectPath);
|
|
291
|
+
recalculateStats(data);
|
|
292
|
+
data.lastUpdated = new Date().toISOString();
|
|
293
|
+
const trackingPath = getTrackingPath(projectPath);
|
|
294
|
+
const dir = dirname(trackingPath);
|
|
295
|
+
if (!existsSync(dir)) {
|
|
296
|
+
mkdirSync(dir, { recursive: true });
|
|
297
|
+
}
|
|
298
|
+
writeFileSync(trackingPath, JSON.stringify(data, null, 2), 'utf-8');
|
|
299
|
+
}
|
|
300
|
+
/**
|
|
301
|
+
* Remove MR from active tracking (keeps in history)
|
|
302
|
+
*/
|
|
303
|
+
export function archiveMr(projectPath, mrId) {
|
|
304
|
+
const data = loadMrTracking(projectPath);
|
|
305
|
+
const index = data.mrs.findIndex((m) => m.id === mrId);
|
|
306
|
+
if (index < 0)
|
|
307
|
+
return false;
|
|
308
|
+
data.mrs.splice(index, 1);
|
|
309
|
+
saveMrTracking(projectPath, data);
|
|
310
|
+
return true;
|
|
311
|
+
}
|
|
312
|
+
/**
|
|
313
|
+
* Toggle auto-followup for a specific MR
|
|
314
|
+
*/
|
|
315
|
+
export function setAutoFollowup(projectPath, mrId, enabled) {
|
|
316
|
+
const data = loadMrTracking(projectPath);
|
|
317
|
+
const mr = data.mrs.find((m) => m.id === mrId);
|
|
318
|
+
if (!mr)
|
|
319
|
+
return null;
|
|
320
|
+
mr.autoFollowup = enabled;
|
|
321
|
+
saveMrTracking(projectPath, data);
|
|
322
|
+
return mr;
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Get MRs pending fix (with open threads or blocking issues)
|
|
326
|
+
*/
|
|
327
|
+
export function getPendingFixMrs(projectPath) {
|
|
328
|
+
const data = loadMrTracking(projectPath);
|
|
329
|
+
return data.mrs.filter((mr) => mr.state === 'pending-fix');
|
|
330
|
+
}
|
|
331
|
+
/**
|
|
332
|
+
* Get MRs pending approval (all threads resolved)
|
|
333
|
+
*/
|
|
334
|
+
export function getPendingApprovalMrs(projectPath) {
|
|
335
|
+
const data = loadMrTracking(projectPath);
|
|
336
|
+
return data.mrs.filter((mr) => mr.state === 'pending-approval');
|
|
337
|
+
}
|
|
338
|
+
/**
|
|
339
|
+
* Get MRs pending initial review
|
|
340
|
+
*/
|
|
341
|
+
export function getPendingReviewMrs(projectPath) {
|
|
342
|
+
const data = loadMrTracking(projectPath);
|
|
343
|
+
return data.mrs.filter((mr) => mr.state === 'pending-review');
|
|
344
|
+
}
|
|
345
|
+
/**
|
|
346
|
+
* Check if a MR needs a followup review
|
|
347
|
+
*/
|
|
348
|
+
export function needsFollowupReview(projectPath, mrNumber, platform) {
|
|
349
|
+
const data = loadMrTracking(projectPath);
|
|
350
|
+
const mr = data.mrs.find((m) => m.mrNumber === mrNumber && m.platform === platform);
|
|
351
|
+
if (!mr)
|
|
352
|
+
return false;
|
|
353
|
+
if (mr.state !== 'pending-fix')
|
|
354
|
+
return false;
|
|
355
|
+
if (!mr.lastPushAt || !mr.lastReviewAt)
|
|
356
|
+
return false;
|
|
357
|
+
const pushTime = new Date(mr.lastPushAt).getTime();
|
|
358
|
+
const reviewTime = new Date(mr.lastReviewAt).getTime();
|
|
359
|
+
return pushTime > reviewTime;
|
|
360
|
+
}
|
|
361
|
+
/**
|
|
362
|
+
* Get tracking stats for a project
|
|
363
|
+
*/
|
|
364
|
+
export function getTrackingStats(projectPath) {
|
|
365
|
+
const data = loadMrTracking(projectPath);
|
|
366
|
+
return data.stats;
|
|
367
|
+
}
|
|
368
|
+
/**
|
|
369
|
+
* Get detailed stats for a specific MR
|
|
370
|
+
*/
|
|
371
|
+
export function getMrDetails(projectPath, mrId) {
|
|
372
|
+
const data = loadMrTracking(projectPath);
|
|
373
|
+
return data.mrs.find((m) => m.id === mrId);
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* Get all active MRs (not merged/closed)
|
|
377
|
+
*/
|
|
378
|
+
export function getActiveMrs(projectPath) {
|
|
379
|
+
const data = loadMrTracking(projectPath);
|
|
380
|
+
return data.mrs.filter((mr) => !['merged', 'closed'].includes(mr.state));
|
|
381
|
+
}
|
|
382
|
+
/**
|
|
383
|
+
* Legacy compatibility - track MR after review (calls new functions)
|
|
384
|
+
*/
|
|
385
|
+
export function trackMrAfterReview(projectPath, mrInfo, threadCount) {
|
|
386
|
+
const mrId = `${mrInfo.platform}-${mrInfo.project}-${mrInfo.mrNumber}`;
|
|
387
|
+
const data = loadMrTracking(projectPath);
|
|
388
|
+
let mr = data.mrs.find((m) => m.id === mrId);
|
|
389
|
+
if (!mr) {
|
|
390
|
+
// Create with minimal info if not exists
|
|
391
|
+
mr = trackMrAssignment(projectPath, {
|
|
392
|
+
...mrInfo,
|
|
393
|
+
sourceBranch: 'unknown',
|
|
394
|
+
targetBranch: 'unknown',
|
|
395
|
+
}, { username: 'unknown' });
|
|
396
|
+
}
|
|
397
|
+
// Update thread counts
|
|
398
|
+
updateMrThreads(projectPath, mrId, threadCount.open, threadCount.total);
|
|
399
|
+
return loadMrTracking(projectPath).mrs.find((m) => m.id === mrId);
|
|
400
|
+
}
|
|
401
|
+
/**
|
|
402
|
+
* Sync thread counts from GitLab API for all active MRs
|
|
403
|
+
*/
|
|
404
|
+
export async function syncGitLabThreads(projectPath) {
|
|
405
|
+
const data = loadMrTracking(projectPath);
|
|
406
|
+
const gitlabMrs = data.mrs.filter((mr) => mr.platform === 'gitlab' && !['merged', 'closed'].includes(mr.state));
|
|
407
|
+
for (const mr of gitlabMrs) {
|
|
408
|
+
try {
|
|
409
|
+
const threads = fetchGitLabThreads(mr.project, mr.mrNumber);
|
|
410
|
+
if (threads) {
|
|
411
|
+
updateMrThreads(projectPath, mr.id, threads.open, threads.total);
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
catch {
|
|
415
|
+
// Silently ignore individual MR sync failures
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
/**
|
|
420
|
+
* Fetch thread counts from GitLab API using glab CLI
|
|
421
|
+
*/
|
|
422
|
+
function fetchGitLabThreads(project, mrNumber) {
|
|
423
|
+
try {
|
|
424
|
+
// URL-encode the project path
|
|
425
|
+
const encodedProject = encodeURIComponent(project);
|
|
426
|
+
// Fetch discussions from GitLab API
|
|
427
|
+
const result = execSync(`glab api "projects/${encodedProject}/merge_requests/${mrNumber}/discussions"`, { encoding: 'utf-8', timeout: 10000 });
|
|
428
|
+
const discussions = JSON.parse(result);
|
|
429
|
+
let total = 0;
|
|
430
|
+
let open = 0;
|
|
431
|
+
let resolvable = 0;
|
|
432
|
+
for (const discussion of discussions) {
|
|
433
|
+
// Skip system notes (not real discussions)
|
|
434
|
+
if (discussion.individual_note)
|
|
435
|
+
continue;
|
|
436
|
+
// Count resolvable threads (code review comments)
|
|
437
|
+
const notes = discussion.notes || [];
|
|
438
|
+
const firstNote = notes[0];
|
|
439
|
+
if (firstNote?.resolvable) {
|
|
440
|
+
resolvable++;
|
|
441
|
+
total++;
|
|
442
|
+
// Check if thread is unresolved
|
|
443
|
+
if (!firstNote.resolved) {
|
|
444
|
+
open++;
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
return { open, total, resolvable };
|
|
449
|
+
}
|
|
450
|
+
catch {
|
|
451
|
+
return null;
|
|
452
|
+
}
|
|
453
|
+
}
|
|
454
|
+
/**
|
|
455
|
+
* Sync a single MR's threads from GitLab or GitHub
|
|
456
|
+
*/
|
|
457
|
+
export function syncSingleMrThreads(projectPath, mrId) {
|
|
458
|
+
const data = loadMrTracking(projectPath);
|
|
459
|
+
const mr = data.mrs.find((m) => m.id === mrId);
|
|
460
|
+
if (!mr) {
|
|
461
|
+
return null;
|
|
462
|
+
}
|
|
463
|
+
let threads = null;
|
|
464
|
+
if (mr.platform === 'gitlab') {
|
|
465
|
+
threads = fetchGitLabThreads(mr.project, mr.mrNumber);
|
|
466
|
+
}
|
|
467
|
+
else if (mr.platform === 'github') {
|
|
468
|
+
threads = fetchGitHubThreads(mr.project, mr.mrNumber);
|
|
469
|
+
}
|
|
470
|
+
if (threads) {
|
|
471
|
+
return updateMrThreads(projectPath, mr.id, threads.open, threads.total) || null;
|
|
472
|
+
}
|
|
473
|
+
return null;
|
|
474
|
+
}
|
|
475
|
+
/**
|
|
476
|
+
* Sync thread counts from GitHub API for all active PRs
|
|
477
|
+
*/
|
|
478
|
+
export async function syncGitHubThreads(projectPath) {
|
|
479
|
+
const data = loadMrTracking(projectPath);
|
|
480
|
+
const githubPrs = data.mrs.filter((mr) => mr.platform === 'github' && !['merged', 'closed'].includes(mr.state));
|
|
481
|
+
for (const pr of githubPrs) {
|
|
482
|
+
try {
|
|
483
|
+
const threads = fetchGitHubThreads(pr.project, pr.mrNumber);
|
|
484
|
+
if (threads) {
|
|
485
|
+
updateMrThreads(projectPath, pr.id, threads.open, threads.total);
|
|
486
|
+
}
|
|
487
|
+
}
|
|
488
|
+
catch {
|
|
489
|
+
// Silently ignore individual PR sync failures
|
|
490
|
+
}
|
|
491
|
+
}
|
|
492
|
+
}
|
|
493
|
+
/**
|
|
494
|
+
* Fetch thread counts from GitHub API using gh CLI
|
|
495
|
+
*/
|
|
496
|
+
function fetchGitHubThreads(repo, prNumber) {
|
|
497
|
+
try {
|
|
498
|
+
// Fetch review threads from GitHub API
|
|
499
|
+
const result = execSync(`gh api "repos/${repo}/pulls/${prNumber}/comments"`, { encoding: 'utf-8', timeout: 10000 });
|
|
500
|
+
const comments = JSON.parse(result);
|
|
501
|
+
// Group comments by thread (in_reply_to_id)
|
|
502
|
+
const threadIds = new Set();
|
|
503
|
+
const resolvedThreads = new Set();
|
|
504
|
+
for (const comment of comments) {
|
|
505
|
+
// Each top-level comment starts a thread
|
|
506
|
+
if (!comment.in_reply_to_id) {
|
|
507
|
+
threadIds.add(comment.id);
|
|
508
|
+
}
|
|
509
|
+
}
|
|
510
|
+
// Check review state (approved/changes_requested)
|
|
511
|
+
try {
|
|
512
|
+
const reviewsResult = execSync(`gh api "repos/${repo}/pulls/${prNumber}/reviews"`, { encoding: 'utf-8', timeout: 10000 });
|
|
513
|
+
const reviews = JSON.parse(reviewsResult);
|
|
514
|
+
// Count pending review threads (not approved yet)
|
|
515
|
+
let _pendingReviews = 0;
|
|
516
|
+
for (const review of reviews) {
|
|
517
|
+
if (review.state === 'CHANGES_REQUESTED' || review.state === 'COMMENTED') {
|
|
518
|
+
_pendingReviews++;
|
|
519
|
+
}
|
|
520
|
+
}
|
|
521
|
+
}
|
|
522
|
+
catch {
|
|
523
|
+
// Ignore review fetch errors
|
|
524
|
+
}
|
|
525
|
+
const total = threadIds.size;
|
|
526
|
+
const open = total - resolvedThreads.size;
|
|
527
|
+
return { open, total };
|
|
528
|
+
}
|
|
529
|
+
catch {
|
|
530
|
+
return null;
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
/**
|
|
534
|
+
* Sync all platforms' threads
|
|
535
|
+
*/
|
|
536
|
+
export async function syncAllThreads(projectPath) {
|
|
537
|
+
await syncGitLabThreads(projectPath);
|
|
538
|
+
await syncGitHubThreads(projectPath);
|
|
539
|
+
}
|
|
540
|
+
//# sourceMappingURL=mrTrackingService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mrTrackingService.js","sourceRoot":"","sources":["../../src/services/mrTrackingService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ReviewContextGateway } from '../entities/reviewContext/reviewContext.gateway.js';
|
|
2
|
+
import type { ReviewContextProgress } from '../entities/reviewContext/reviewContext.js';
|
|
3
|
+
export type ProgressCallback = (progress: ReviewContextProgress) => void;
|
|
4
|
+
export declare class ReviewContextWatcherService {
|
|
5
|
+
private gateway;
|
|
6
|
+
private pollingIntervalMs;
|
|
7
|
+
private watchers;
|
|
8
|
+
private lastProgress;
|
|
9
|
+
constructor(gateway: ReviewContextGateway, pollingIntervalMs?: number);
|
|
10
|
+
start(localPath: string, mergeRequestId: string, callback: ProgressCallback): void;
|
|
11
|
+
isWatching(mergeRequestId: string): boolean;
|
|
12
|
+
stop(mergeRequestId: string): void;
|
|
13
|
+
stopAll(): void;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=reviewContextWatcher.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewContextWatcher.service.d.ts","sourceRoot":"","sources":["../../src/services/reviewContextWatcher.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,oDAAoD,CAAA;AAC9F,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAA;AAEvF,MAAM,MAAM,gBAAgB,GAAG,CAAC,QAAQ,EAAE,qBAAqB,KAAK,IAAI,CAAA;AAIxE,qBAAa,2BAA2B;IAKpC,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,iBAAiB;IAL3B,OAAO,CAAC,QAAQ,CAAoC;IACpD,OAAO,CAAC,YAAY,CAA4B;gBAGtC,OAAO,EAAE,oBAAoB,EAC7B,iBAAiB,SAA8B;IAGzD,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,GAAG,IAAI;IAkBlF,UAAU,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO;IAI3C,IAAI,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IASlC,OAAO,IAAI,IAAI;CAKhB"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
const DEFAULT_POLLING_INTERVAL_MS = 500;
|
|
2
|
+
export class ReviewContextWatcherService {
|
|
3
|
+
gateway;
|
|
4
|
+
pollingIntervalMs;
|
|
5
|
+
watchers = new Map();
|
|
6
|
+
lastProgress = new Map();
|
|
7
|
+
constructor(gateway, pollingIntervalMs = DEFAULT_POLLING_INTERVAL_MS) {
|
|
8
|
+
this.gateway = gateway;
|
|
9
|
+
this.pollingIntervalMs = pollingIntervalMs;
|
|
10
|
+
}
|
|
11
|
+
start(localPath, mergeRequestId, callback) {
|
|
12
|
+
const interval = setInterval(() => {
|
|
13
|
+
const context = this.gateway.read(localPath, mergeRequestId);
|
|
14
|
+
if (context) {
|
|
15
|
+
const progressKey = JSON.stringify(context.progress);
|
|
16
|
+
if (progressKey !== this.lastProgress.get(mergeRequestId)) {
|
|
17
|
+
this.lastProgress.set(mergeRequestId, progressKey);
|
|
18
|
+
callback(context.progress);
|
|
19
|
+
if (context.progress.phase === 'completed') {
|
|
20
|
+
this.stop(mergeRequestId);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}, this.pollingIntervalMs);
|
|
25
|
+
this.watchers.set(mergeRequestId, interval);
|
|
26
|
+
}
|
|
27
|
+
isWatching(mergeRequestId) {
|
|
28
|
+
return this.watchers.has(mergeRequestId);
|
|
29
|
+
}
|
|
30
|
+
stop(mergeRequestId) {
|
|
31
|
+
const interval = this.watchers.get(mergeRequestId);
|
|
32
|
+
if (interval) {
|
|
33
|
+
clearInterval(interval);
|
|
34
|
+
this.watchers.delete(mergeRequestId);
|
|
35
|
+
this.lastProgress.delete(mergeRequestId);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
stopAll() {
|
|
39
|
+
for (const [mergeRequestId] of this.watchers) {
|
|
40
|
+
this.stop(mergeRequestId);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=reviewContextWatcher.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewContextWatcher.service.js","sourceRoot":"","sources":["../../src/services/reviewContextWatcher.service.ts"],"names":[],"mappings":"AAKA,MAAM,2BAA2B,GAAG,GAAG,CAAA;AAEvC,MAAM,OAAO,2BAA2B;IAK5B;IACA;IALF,QAAQ,GAAG,IAAI,GAAG,EAA0B,CAAA;IAC5C,YAAY,GAAG,IAAI,GAAG,EAAkB,CAAA;IAEhD,YACU,OAA6B,EAC7B,oBAAoB,2BAA2B;QAD/C,YAAO,GAAP,OAAO,CAAsB;QAC7B,sBAAiB,GAAjB,iBAAiB,CAA8B;IACtD,CAAC;IAEJ,KAAK,CAAC,SAAiB,EAAE,cAAsB,EAAE,QAA0B;QACzE,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,cAAc,CAAC,CAAA;YAC5D,IAAI,OAAO,EAAE,CAAC;gBACZ,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;gBACpD,IAAI,WAAW,KAAK,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC;oBAC1D,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,cAAc,EAAE,WAAW,CAAC,CAAA;oBAClD,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;oBAE1B,IAAI,OAAO,CAAC,QAAQ,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;wBAC3C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;oBAC3B,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAA;QAC1B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAA;IAC7C,CAAC;IAED,UAAU,CAAC,cAAsB;QAC/B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;IAC1C,CAAC;IAED,IAAI,CAAC,cAAsB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;QAClD,IAAI,QAAQ,EAAE,CAAC;YACb,aAAa,CAAC,QAAQ,CAAC,CAAA;YACvB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;YACpC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;QAC1C,CAAC;IACH,CAAC;IAED,OAAO;QACL,KAAK,MAAM,CAAC,cAAc,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;QAC3B,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtimeSettings.d.ts","sourceRoot":"","sources":["../../src/services/runtimeSettings.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,QAAQ,EACR,QAAQ,EACR,WAAW,GACZ,MAAM,2CAA2C,CAAC;AAEnD,YAAY,EAAE,WAAW,EAAE,MAAM,2CAA2C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtimeSettings.js","sourceRoot":"","sources":["../../src/services/runtimeSettings.ts"],"names":[],"mappings":"AAAA,6CAA6C;AAC7C,yDAAyD;AACzD,OAAO,EACL,QAAQ,EACR,QAAQ,EACR,WAAW,GACZ,MAAM,2CAA2C,CAAC"}
|