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,461 @@
|
|
|
1
|
+
import { verifyGitLabSignature, getGitLabEventType } from '../../../security/verifier.js';
|
|
2
|
+
import { gitLabMergeRequestEventGuard } from '../../../entities/gitlab/gitlabMergeRequestEvent.guard.js';
|
|
3
|
+
import { filterGitLabEvent, filterGitLabMrUpdate, filterGitLabMrClose, filterGitLabMrMerge, filterGitLabMrApprove } from './eventFilter.js';
|
|
4
|
+
import { findRepositoryByProjectPath } from '../../../config/loader.js';
|
|
5
|
+
import { enqueueReview, createJobId, updateJobProgress, cancelJob, } from '../../../queue/reviewQueue.js';
|
|
6
|
+
import { invokeClaudeReview, sendNotification } from '../../../claude/invoker.js';
|
|
7
|
+
import { TrackAssignmentUseCase } from '../../../usecases/tracking/trackAssignment.usecase.js';
|
|
8
|
+
import { RecordReviewCompletionUseCase } from '../../../usecases/tracking/recordReviewCompletion.usecase.js';
|
|
9
|
+
import { RecordPushUseCase } from '../../../usecases/tracking/recordPush.usecase.js';
|
|
10
|
+
import { TransitionStateUseCase } from '../../../usecases/tracking/transitionState.usecase.js';
|
|
11
|
+
import { CheckFollowupNeededUseCase } from '../../../usecases/tracking/checkFollowupNeeded.usecase.js';
|
|
12
|
+
import { SyncThreadsUseCase } from '../../../usecases/tracking/syncThreads.usecase.js';
|
|
13
|
+
import { loadProjectConfig, getProjectAgents, getFollowupAgents } from '../../../config/projectConfig.js';
|
|
14
|
+
import { DEFAULT_AGENTS, DEFAULT_FOLLOWUP_AGENTS } from '../../../entities/progress/agentDefinition.type.js';
|
|
15
|
+
import { parseReviewOutput } from '../../../services/statsService.js';
|
|
16
|
+
import { parseThreadActions } from '../../../services/threadActionsParser.js';
|
|
17
|
+
import { executeThreadActions, defaultCommandExecutor } from '../../../services/threadActionsExecutor.js';
|
|
18
|
+
import { executeActionsFromContext } from '../../../services/contextActionsExecutor.js';
|
|
19
|
+
import { ReviewContextFileSystemGateway } from '../../gateways/reviewContext.fileSystem.gateway.js';
|
|
20
|
+
import { GitLabThreadFetchGateway, defaultGitLabExecutor } from '../../gateways/threadFetch.gitlab.gateway.js';
|
|
21
|
+
import { GitLabDiffMetadataFetchGateway } from '../../gateways/diffMetadataFetch.gitlab.gateway.js';
|
|
22
|
+
import { startWatchingReviewContext, stopWatchingReviewContext } from '../../../main/websocket.js';
|
|
23
|
+
export async function handleGitLabWebhook(request, reply, logger, trackingGateway) {
|
|
24
|
+
const trackAssignment = new TrackAssignmentUseCase(trackingGateway);
|
|
25
|
+
const recordCompletion = new RecordReviewCompletionUseCase(trackingGateway);
|
|
26
|
+
const recordPush = new RecordPushUseCase(trackingGateway);
|
|
27
|
+
const transitionState = new TransitionStateUseCase(trackingGateway);
|
|
28
|
+
const checkFollowupNeeded = new CheckFollowupNeededUseCase(trackingGateway);
|
|
29
|
+
// 1. Verify signature
|
|
30
|
+
const verification = verifyGitLabSignature(request);
|
|
31
|
+
if (!verification.valid) {
|
|
32
|
+
logger.warn({ error: verification.error }, 'GitLab signature verification failed');
|
|
33
|
+
reply.status(401).send({ error: verification.error });
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
// 2. Check event type
|
|
37
|
+
const eventType = getGitLabEventType(request);
|
|
38
|
+
if (eventType !== 'Merge Request Hook') {
|
|
39
|
+
logger.debug({ eventType }, 'Ignoring non-MR event');
|
|
40
|
+
reply.status(200).send({ status: 'ignored', reason: 'Not a MR event' });
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
// 3. Parse and validate event
|
|
44
|
+
const parseResult = gitLabMergeRequestEventGuard.safeParse(request.body);
|
|
45
|
+
if (!parseResult.success) {
|
|
46
|
+
logger.warn({ errors: parseResult.error }, 'Invalid GitLab webhook payload');
|
|
47
|
+
reply.status(400).send({ error: 'Invalid webhook payload' });
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
const event = parseResult.data;
|
|
51
|
+
// 3a. Check if MR was closed - clean up tracking and cancel any running job
|
|
52
|
+
const closeResult = filterGitLabMrClose(event);
|
|
53
|
+
if (closeResult.shouldProcess) {
|
|
54
|
+
const projectPath = closeResult.projectPath;
|
|
55
|
+
const mrNumber = closeResult.mergeRequestNumber;
|
|
56
|
+
const mrId = `gitlab-${projectPath}-${mrNumber}`;
|
|
57
|
+
// Find repo config
|
|
58
|
+
const repoConfig = findRepositoryByProjectPath(projectPath);
|
|
59
|
+
if (repoConfig) {
|
|
60
|
+
// Cancel any running job for this MR
|
|
61
|
+
const jobId = createJobId('gitlab', projectPath, mrNumber);
|
|
62
|
+
const cancelled = cancelJob(jobId);
|
|
63
|
+
// Archive the MR from tracking
|
|
64
|
+
const archived = trackingGateway.archive(repoConfig.localPath, mrId);
|
|
65
|
+
// Delete review context file
|
|
66
|
+
const contextGateway = new ReviewContextFileSystemGateway();
|
|
67
|
+
const contextDeleted = contextGateway.delete(repoConfig.localPath, mrId);
|
|
68
|
+
logger.info({
|
|
69
|
+
mrNumber,
|
|
70
|
+
project: projectPath,
|
|
71
|
+
jobCancelled: cancelled,
|
|
72
|
+
trackingArchived: archived,
|
|
73
|
+
contextDeleted: contextDeleted.deleted,
|
|
74
|
+
}, 'MR closed - cleaned up tracking and cancelled job');
|
|
75
|
+
reply.status(200).send({
|
|
76
|
+
status: 'cleaned',
|
|
77
|
+
mrNumber,
|
|
78
|
+
jobCancelled: cancelled,
|
|
79
|
+
trackingArchived: archived,
|
|
80
|
+
});
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
// No repo config, just acknowledge
|
|
84
|
+
logger.info({ mrNumber, project: projectPath }, 'MR closed but repo not configured');
|
|
85
|
+
reply.status(200).send({ status: 'ignored', reason: 'MR closed, repo not configured' });
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
// 3b. Check if MR was merged - update tracking state
|
|
89
|
+
const mergeResult = filterGitLabMrMerge(event);
|
|
90
|
+
if (mergeResult.shouldProcess) {
|
|
91
|
+
const repoConfig = findRepositoryByProjectPath(mergeResult.projectPath);
|
|
92
|
+
if (repoConfig) {
|
|
93
|
+
const mrId = `gitlab-${mergeResult.projectPath}-${mergeResult.mergeRequestNumber}`;
|
|
94
|
+
transitionState.execute({ projectPath: repoConfig.localPath, mrId, targetState: 'merged' });
|
|
95
|
+
logger.info({ mrNumber: mergeResult.mergeRequestNumber }, 'MR marked as merged');
|
|
96
|
+
reply.status(200).send({ status: 'merged', mrNumber: mergeResult.mergeRequestNumber });
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
// 3c. Check if MR was approved - update tracking state
|
|
101
|
+
const approveResult = filterGitLabMrApprove(event);
|
|
102
|
+
if (approveResult.shouldProcess) {
|
|
103
|
+
const repoConfig = findRepositoryByProjectPath(approveResult.projectPath);
|
|
104
|
+
if (repoConfig) {
|
|
105
|
+
const mrId = `gitlab-${approveResult.projectPath}-${approveResult.mergeRequestNumber}`;
|
|
106
|
+
transitionState.execute({ projectPath: repoConfig.localPath, mrId, targetState: 'approved' });
|
|
107
|
+
logger.info({ mrNumber: approveResult.mergeRequestNumber }, 'MR marked as approved');
|
|
108
|
+
reply.status(200).send({ status: 'approved', mrNumber: approveResult.mergeRequestNumber });
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
// 3d. Filter for review assignment
|
|
113
|
+
const filterResult = filterGitLabEvent(event);
|
|
114
|
+
// Debug: log reviewers data
|
|
115
|
+
logger.info({
|
|
116
|
+
project: event.project?.path_with_namespace,
|
|
117
|
+
mrIid: event.object_attributes?.iid,
|
|
118
|
+
action: event.object_attributes?.action,
|
|
119
|
+
reviewers: event.reviewers?.map(r => r.username) || 'NONE',
|
|
120
|
+
changesReviewers: event.changes?.reviewers ? 'YES' : 'NO',
|
|
121
|
+
shouldProcess: filterResult.shouldProcess,
|
|
122
|
+
reason: filterResult.reason,
|
|
123
|
+
}, 'GitLab MR event received');
|
|
124
|
+
if (!filterResult.shouldProcess) {
|
|
125
|
+
// Check if this is an MR update that might need a followup review
|
|
126
|
+
const updateResult = filterGitLabMrUpdate(event);
|
|
127
|
+
logger.debug({ updateResult, action: event.object_attributes?.action }, 'Checking for followup review');
|
|
128
|
+
if (updateResult.shouldProcess && updateResult.isFollowup) {
|
|
129
|
+
// Find repo config to get local path
|
|
130
|
+
const updateRepoConfig = findRepositoryByProjectPath(updateResult.projectPath);
|
|
131
|
+
if (updateRepoConfig) {
|
|
132
|
+
// Record the push event
|
|
133
|
+
const mr = recordPush.execute({ projectPath: updateRepoConfig.localPath, mrNumber: updateResult.mergeRequestNumber, platform: 'gitlab' });
|
|
134
|
+
logger.info({
|
|
135
|
+
mrNumber: updateResult.mergeRequestNumber,
|
|
136
|
+
mrFound: !!mr,
|
|
137
|
+
mrState: mr?.state,
|
|
138
|
+
lastPushAt: mr?.lastPushAt,
|
|
139
|
+
lastReviewAt: mr?.lastReviewAt,
|
|
140
|
+
}, 'Push event recorded');
|
|
141
|
+
// Check if this MR needs a followup (has open threads and was pushed since last review)
|
|
142
|
+
const needsFollowup = mr && checkFollowupNeeded.execute({ projectPath: updateRepoConfig.localPath, mrNumber: updateResult.mergeRequestNumber, platform: 'gitlab' });
|
|
143
|
+
logger.info({ needsFollowup, mrState: mr?.state }, 'Followup check result');
|
|
144
|
+
if (needsFollowup) {
|
|
145
|
+
if (mr.autoFollowup === false) {
|
|
146
|
+
logger.info({ mrNumber: updateResult.mergeRequestNumber, project: updateResult.projectPath }, 'Auto-followup disabled for this MR, skipping');
|
|
147
|
+
reply.status(200).send({ status: 'ignored', reason: 'Auto-followup disabled' });
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
logger.info({ mrNumber: updateResult.mergeRequestNumber, project: updateResult.projectPath }, 'Auto-triggering followup review after push');
|
|
151
|
+
const projectConfig = loadProjectConfig(updateRepoConfig.localPath);
|
|
152
|
+
const skill = projectConfig?.reviewFollowupSkill || 'review-followup';
|
|
153
|
+
const followupJobId = createJobId('gitlab-followup', updateResult.projectPath, updateResult.mergeRequestNumber);
|
|
154
|
+
const followupJob = {
|
|
155
|
+
id: followupJobId,
|
|
156
|
+
platform: 'gitlab',
|
|
157
|
+
projectPath: updateResult.projectPath,
|
|
158
|
+
localPath: updateRepoConfig.localPath,
|
|
159
|
+
mrNumber: updateResult.mergeRequestNumber,
|
|
160
|
+
skill,
|
|
161
|
+
mrUrl: updateResult.mergeRequestUrl,
|
|
162
|
+
sourceBranch: updateResult.sourceBranch,
|
|
163
|
+
targetBranch: updateResult.targetBranch,
|
|
164
|
+
jobType: 'followup',
|
|
165
|
+
};
|
|
166
|
+
enqueueReview(followupJob, async (j, signal) => {
|
|
167
|
+
sendNotification('Review followup démarrée', `MR !${j.mrNumber} - ${j.projectPath}`, logger);
|
|
168
|
+
// Create review context file with pre-fetched threads and diff metadata
|
|
169
|
+
const mergeRequestId = `gitlab-${j.projectPath}-${j.mrNumber}`;
|
|
170
|
+
const contextGateway = new ReviewContextFileSystemGateway();
|
|
171
|
+
const threadFetchGateway = new GitLabThreadFetchGateway(defaultGitLabExecutor);
|
|
172
|
+
const diffMetadataFetchGateway = new GitLabDiffMetadataFetchGateway(defaultGitLabExecutor);
|
|
173
|
+
try {
|
|
174
|
+
const threads = threadFetchGateway.fetchThreads(j.projectPath, j.mrNumber);
|
|
175
|
+
let diffMetadata;
|
|
176
|
+
try {
|
|
177
|
+
diffMetadata = diffMetadataFetchGateway.fetchDiffMetadata(j.projectPath, j.mrNumber);
|
|
178
|
+
}
|
|
179
|
+
catch (error) {
|
|
180
|
+
logger.warn({ mrNumber: j.mrNumber, error: error instanceof Error ? error.message : String(error) }, 'Failed to fetch diff metadata for followup, inline comments will be skipped');
|
|
181
|
+
}
|
|
182
|
+
const followupAgentsList = getFollowupAgents(j.localPath) ?? DEFAULT_FOLLOWUP_AGENTS;
|
|
183
|
+
contextGateway.create({
|
|
184
|
+
localPath: j.localPath,
|
|
185
|
+
mergeRequestId,
|
|
186
|
+
platform: 'gitlab',
|
|
187
|
+
projectPath: j.projectPath,
|
|
188
|
+
mergeRequestNumber: j.mrNumber,
|
|
189
|
+
threads,
|
|
190
|
+
agents: followupAgentsList,
|
|
191
|
+
diffMetadata,
|
|
192
|
+
});
|
|
193
|
+
logger.info({ mrNumber: j.mrNumber, threadsCount: threads.length, hasDiffMetadata: !!diffMetadata }, 'Review context file created with threads for followup');
|
|
194
|
+
startWatchingReviewContext(j.id, j.localPath, mergeRequestId);
|
|
195
|
+
logger.info({ mrNumber: j.mrNumber }, 'Started watching review context for live progress');
|
|
196
|
+
}
|
|
197
|
+
catch (error) {
|
|
198
|
+
logger.warn({ mrNumber: j.mrNumber, error: error instanceof Error ? error.message : String(error) }, 'Failed to create review context file for followup, continuing without it');
|
|
199
|
+
}
|
|
200
|
+
const result = await invokeClaudeReview(j, logger, (progress, progressEvent) => {
|
|
201
|
+
updateJobProgress(j.id, progress, progressEvent);
|
|
202
|
+
// Also update the review context file for file-based progress tracking
|
|
203
|
+
const runningAgent = progress.agents.find(a => a.status === 'running');
|
|
204
|
+
const completedAgents = progress.agents
|
|
205
|
+
.filter(a => a.status === 'completed')
|
|
206
|
+
.map(a => a.name);
|
|
207
|
+
contextGateway.updateProgress(j.localPath, mergeRequestId, {
|
|
208
|
+
phase: progress.currentPhase,
|
|
209
|
+
currentStep: runningAgent?.name ?? null,
|
|
210
|
+
stepsCompleted: completedAgents,
|
|
211
|
+
});
|
|
212
|
+
}, signal);
|
|
213
|
+
stopWatchingReviewContext(mergeRequestId);
|
|
214
|
+
if (result.success) {
|
|
215
|
+
// Parse review output for stats
|
|
216
|
+
const parsed = parseReviewOutput(result.stdout);
|
|
217
|
+
let threadResolveCount = 0;
|
|
218
|
+
// PRIMARY: Execute actions from context file (agent writes actions here)
|
|
219
|
+
const reviewContext = contextGateway.read(j.localPath, mergeRequestId);
|
|
220
|
+
if (reviewContext && reviewContext.actions.length > 0) {
|
|
221
|
+
threadResolveCount = reviewContext.actions.filter(a => a.type === 'THREAD_RESOLVE').length;
|
|
222
|
+
const contextActionResult = await executeActionsFromContext(reviewContext, j.localPath, logger, defaultCommandExecutor);
|
|
223
|
+
logger.info({ ...contextActionResult, threadResolveCount, mrNumber: j.mrNumber }, 'Actions executed from context file for followup');
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
// FALLBACK: Execute thread actions from stdout markers (backward compatibility)
|
|
227
|
+
const threadActions = parseThreadActions(result.stdout);
|
|
228
|
+
if (threadActions.length > 0) {
|
|
229
|
+
threadResolveCount = threadActions.filter(a => a.type === 'THREAD_RESOLVE').length;
|
|
230
|
+
const actionResult = await executeThreadActions(threadActions, {
|
|
231
|
+
platform: 'gitlab',
|
|
232
|
+
projectPath: j.projectPath,
|
|
233
|
+
mrNumber: j.mrNumber,
|
|
234
|
+
localPath: j.localPath,
|
|
235
|
+
}, logger, defaultCommandExecutor);
|
|
236
|
+
logger.info({ ...actionResult, threadResolveCount, mrNumber: j.mrNumber }, 'Thread actions executed from stdout markers for followup (fallback)');
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
// Sync threads from GitLab FIRST to get real state after followup resolves threads
|
|
240
|
+
const mrId = `gitlab-${j.projectPath}-${j.mrNumber}`;
|
|
241
|
+
const syncUseCase = new SyncThreadsUseCase(trackingGateway, threadFetchGateway);
|
|
242
|
+
const updatedMr = syncUseCase.execute({ projectPath: j.localPath, mrId });
|
|
243
|
+
// Record followup completion with parsed stats
|
|
244
|
+
// threadsClosed comes from THREAD_RESOLVE markers parsed from output
|
|
245
|
+
recordCompletion.execute({
|
|
246
|
+
projectPath: j.localPath,
|
|
247
|
+
mrId,
|
|
248
|
+
reviewData: {
|
|
249
|
+
type: 'followup',
|
|
250
|
+
durationMs: result.durationMs,
|
|
251
|
+
score: parsed.score,
|
|
252
|
+
blocking: parsed.blocking,
|
|
253
|
+
warnings: parsed.warnings,
|
|
254
|
+
suggestions: parsed.suggestions,
|
|
255
|
+
threadsOpened: 0,
|
|
256
|
+
threadsClosed: threadResolveCount,
|
|
257
|
+
},
|
|
258
|
+
});
|
|
259
|
+
logger.info({
|
|
260
|
+
mrNumber: j.mrNumber,
|
|
261
|
+
score: parsed.score,
|
|
262
|
+
blocking: parsed.blocking,
|
|
263
|
+
warnings: parsed.warnings,
|
|
264
|
+
suggestions: parsed.suggestions,
|
|
265
|
+
durationMs: result.durationMs,
|
|
266
|
+
openThreads: updatedMr?.openThreads,
|
|
267
|
+
state: updatedMr?.state,
|
|
268
|
+
}, 'Followup stats recorded and threads synced');
|
|
269
|
+
sendNotification('Review followup terminée', `MR !${j.mrNumber} - ${j.projectPath}`, logger);
|
|
270
|
+
}
|
|
271
|
+
else if (!result.cancelled) {
|
|
272
|
+
sendNotification('Review followup échouée', `MR !${j.mrNumber} - Code ${result.exitCode}`, logger);
|
|
273
|
+
throw new Error(`Followup review failed with exit code ${result.exitCode}`);
|
|
274
|
+
}
|
|
275
|
+
});
|
|
276
|
+
reply.status(202).send({
|
|
277
|
+
status: 'followup-queued',
|
|
278
|
+
jobId: followupJobId,
|
|
279
|
+
mrNumber: updateResult.mergeRequestNumber,
|
|
280
|
+
});
|
|
281
|
+
return;
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
reply.status(200).send({ status: 'ignored', reason: filterResult.reason });
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
// 4. Find repository configuration
|
|
289
|
+
const repoConfig = findRepositoryByProjectPath(filterResult.projectPath);
|
|
290
|
+
if (!repoConfig) {
|
|
291
|
+
logger.warn({ projectPath: filterResult.projectPath }, 'Projet non configuré');
|
|
292
|
+
reply.status(200).send({
|
|
293
|
+
status: 'ignored',
|
|
294
|
+
reason: 'Repository not configured',
|
|
295
|
+
});
|
|
296
|
+
return;
|
|
297
|
+
}
|
|
298
|
+
// 5. Track MR assignment with user info
|
|
299
|
+
// Use MR assignee (actual owner), not webhook trigger (who added the reviewer)
|
|
300
|
+
const mrTitle = event.object_attributes?.title || `MR !${filterResult.mergeRequestNumber}`;
|
|
301
|
+
const mrAssignee = event.assignees?.[0];
|
|
302
|
+
const assignedBy = {
|
|
303
|
+
username: mrAssignee?.username || event.user?.username || 'unknown',
|
|
304
|
+
displayName: mrAssignee?.name || event.user?.name,
|
|
305
|
+
};
|
|
306
|
+
trackAssignment.execute({
|
|
307
|
+
projectPath: repoConfig.localPath,
|
|
308
|
+
mrInfo: {
|
|
309
|
+
mrNumber: filterResult.mergeRequestNumber,
|
|
310
|
+
title: mrTitle,
|
|
311
|
+
url: filterResult.mergeRequestUrl,
|
|
312
|
+
project: filterResult.projectPath,
|
|
313
|
+
platform: 'gitlab',
|
|
314
|
+
sourceBranch: filterResult.sourceBranch,
|
|
315
|
+
targetBranch: filterResult.targetBranch,
|
|
316
|
+
},
|
|
317
|
+
assignedBy,
|
|
318
|
+
});
|
|
319
|
+
logger.info({ mrNumber: filterResult.mergeRequestNumber, assignedBy: assignedBy.username }, 'MR tracked for review');
|
|
320
|
+
// 6. Create and enqueue job
|
|
321
|
+
const jobId = createJobId('gitlab', filterResult.projectPath, filterResult.mergeRequestNumber);
|
|
322
|
+
const job = {
|
|
323
|
+
id: jobId,
|
|
324
|
+
platform: 'gitlab',
|
|
325
|
+
projectPath: filterResult.projectPath,
|
|
326
|
+
localPath: repoConfig.localPath,
|
|
327
|
+
mrNumber: filterResult.mergeRequestNumber,
|
|
328
|
+
skill: repoConfig.skill,
|
|
329
|
+
mrUrl: filterResult.mergeRequestUrl,
|
|
330
|
+
sourceBranch: filterResult.sourceBranch,
|
|
331
|
+
targetBranch: filterResult.targetBranch,
|
|
332
|
+
jobType: 'review',
|
|
333
|
+
// MR metadata for dashboard
|
|
334
|
+
title: mrTitle,
|
|
335
|
+
description: event.object_attributes?.description,
|
|
336
|
+
assignedBy,
|
|
337
|
+
};
|
|
338
|
+
const enqueued = await enqueueReview(job, async (j, signal) => {
|
|
339
|
+
// Send start notification
|
|
340
|
+
sendNotification('Review démarrée', `MR !${j.mrNumber} - ${j.projectPath}`, logger);
|
|
341
|
+
// Create review context file with pre-fetched threads and diff metadata
|
|
342
|
+
const mergeRequestId = `gitlab-${j.projectPath}-${j.mrNumber}`;
|
|
343
|
+
const contextGateway = new ReviewContextFileSystemGateway();
|
|
344
|
+
const threadFetchGateway = new GitLabThreadFetchGateway(defaultGitLabExecutor);
|
|
345
|
+
const diffMetadataFetchGateway = new GitLabDiffMetadataFetchGateway(defaultGitLabExecutor);
|
|
346
|
+
try {
|
|
347
|
+
const threads = threadFetchGateway.fetchThreads(j.projectPath, j.mrNumber);
|
|
348
|
+
let diffMetadata;
|
|
349
|
+
try {
|
|
350
|
+
diffMetadata = diffMetadataFetchGateway.fetchDiffMetadata(j.projectPath, j.mrNumber);
|
|
351
|
+
}
|
|
352
|
+
catch (error) {
|
|
353
|
+
logger.warn({ mrNumber: j.mrNumber, error: error instanceof Error ? error.message : String(error) }, 'Failed to fetch diff metadata, inline comments will be skipped');
|
|
354
|
+
}
|
|
355
|
+
const reviewAgentsList = getProjectAgents(j.localPath) ?? DEFAULT_AGENTS;
|
|
356
|
+
contextGateway.create({
|
|
357
|
+
localPath: j.localPath,
|
|
358
|
+
mergeRequestId,
|
|
359
|
+
platform: 'gitlab',
|
|
360
|
+
projectPath: j.projectPath,
|
|
361
|
+
mergeRequestNumber: j.mrNumber,
|
|
362
|
+
threads,
|
|
363
|
+
agents: reviewAgentsList,
|
|
364
|
+
diffMetadata,
|
|
365
|
+
});
|
|
366
|
+
logger.info({ mrNumber: j.mrNumber, threadsCount: threads.length, hasDiffMetadata: !!diffMetadata }, 'Review context file created with threads');
|
|
367
|
+
startWatchingReviewContext(j.id, j.localPath, mergeRequestId);
|
|
368
|
+
logger.info({ mrNumber: j.mrNumber }, 'Started watching review context for live progress');
|
|
369
|
+
}
|
|
370
|
+
catch (error) {
|
|
371
|
+
logger.warn({ mrNumber: j.mrNumber, error: error instanceof Error ? error.message : String(error) }, 'Failed to create review context file, continuing without it');
|
|
372
|
+
}
|
|
373
|
+
// Invoke Claude with progress tracking and cancellation support
|
|
374
|
+
const result = await invokeClaudeReview(j, logger, (progress, progressEvent) => {
|
|
375
|
+
updateJobProgress(j.id, progress, progressEvent);
|
|
376
|
+
// Also update the review context file for file-based progress tracking
|
|
377
|
+
const runningAgent = progress.agents.find(a => a.status === 'running');
|
|
378
|
+
const completedAgents = progress.agents
|
|
379
|
+
.filter(a => a.status === 'completed')
|
|
380
|
+
.map(a => a.name);
|
|
381
|
+
contextGateway.updateProgress(j.localPath, mergeRequestId, {
|
|
382
|
+
phase: progress.currentPhase,
|
|
383
|
+
currentStep: runningAgent?.name ?? null,
|
|
384
|
+
stepsCompleted: completedAgents,
|
|
385
|
+
});
|
|
386
|
+
}, signal);
|
|
387
|
+
// Stop watching context file (auto-stops on completion, but explicit stop for error cases)
|
|
388
|
+
stopWatchingReviewContext(mergeRequestId);
|
|
389
|
+
// Send completion notification and record stats
|
|
390
|
+
if (result.cancelled) {
|
|
391
|
+
sendNotification('Review annulée', `MR !${j.mrNumber} - ${j.projectPath}`, logger);
|
|
392
|
+
}
|
|
393
|
+
else if (result.success) {
|
|
394
|
+
// Parse review output for stats
|
|
395
|
+
const parsed = parseReviewOutput(result.stdout);
|
|
396
|
+
// PRIMARY: Execute actions from context file (agent writes actions here)
|
|
397
|
+
const reviewContext = contextGateway.read(j.localPath, mergeRequestId);
|
|
398
|
+
if (reviewContext && reviewContext.actions.length > 0) {
|
|
399
|
+
const contextActionResult = await executeActionsFromContext(reviewContext, j.localPath, logger, defaultCommandExecutor);
|
|
400
|
+
logger.info({ ...contextActionResult, mrNumber: j.mrNumber }, 'Actions executed from context file');
|
|
401
|
+
}
|
|
402
|
+
else {
|
|
403
|
+
// FALLBACK: Execute thread actions from stdout markers (backward compatibility)
|
|
404
|
+
const threadActions = parseThreadActions(result.stdout);
|
|
405
|
+
if (threadActions.length > 0) {
|
|
406
|
+
const actionResult = await executeThreadActions(threadActions, {
|
|
407
|
+
platform: 'gitlab',
|
|
408
|
+
projectPath: j.projectPath,
|
|
409
|
+
mrNumber: j.mrNumber,
|
|
410
|
+
localPath: j.localPath,
|
|
411
|
+
}, logger, defaultCommandExecutor);
|
|
412
|
+
logger.info({ ...actionResult, mrNumber: j.mrNumber }, 'Thread actions executed from stdout markers (fallback)');
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
// Record review completion with parsed stats
|
|
416
|
+
// Only blocking issues count as open threads - warnings are informational
|
|
417
|
+
recordCompletion.execute({
|
|
418
|
+
projectPath: j.localPath,
|
|
419
|
+
mrId: `gitlab-${j.projectPath}-${j.mrNumber}`,
|
|
420
|
+
reviewData: {
|
|
421
|
+
type: 'review',
|
|
422
|
+
durationMs: result.durationMs,
|
|
423
|
+
score: parsed.score,
|
|
424
|
+
blocking: parsed.blocking,
|
|
425
|
+
warnings: parsed.warnings,
|
|
426
|
+
suggestions: parsed.suggestions,
|
|
427
|
+
threadsOpened: parsed.blocking, // Only blocking issues open threads
|
|
428
|
+
},
|
|
429
|
+
});
|
|
430
|
+
logger.info({
|
|
431
|
+
mrNumber: j.mrNumber,
|
|
432
|
+
score: parsed.score,
|
|
433
|
+
blocking: parsed.blocking,
|
|
434
|
+
warnings: parsed.warnings,
|
|
435
|
+
suggestions: parsed.suggestions,
|
|
436
|
+
durationMs: result.durationMs,
|
|
437
|
+
}, 'Review stats recorded');
|
|
438
|
+
sendNotification('Review terminée', `MR !${j.mrNumber} - ${j.projectPath}`, logger);
|
|
439
|
+
}
|
|
440
|
+
else {
|
|
441
|
+
sendNotification('Review échouée', `MR !${j.mrNumber} - Code ${result.exitCode}`, logger);
|
|
442
|
+
// Throw to mark job as failed (allows retry)
|
|
443
|
+
throw new Error(`Review failed with exit code ${result.exitCode}`);
|
|
444
|
+
}
|
|
445
|
+
});
|
|
446
|
+
if (enqueued) {
|
|
447
|
+
reply.status(202).send({
|
|
448
|
+
status: 'queued',
|
|
449
|
+
jobId,
|
|
450
|
+
mrNumber: filterResult.mergeRequestNumber,
|
|
451
|
+
});
|
|
452
|
+
}
|
|
453
|
+
else {
|
|
454
|
+
reply.status(200).send({
|
|
455
|
+
status: 'deduplicated',
|
|
456
|
+
jobId,
|
|
457
|
+
reason: 'Review already in progress or recently completed',
|
|
458
|
+
});
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
//# sourceMappingURL=gitlab.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitlab.controller.js","sourceRoot":"","sources":["../../../../src/interface-adapters/controllers/webhook/gitlab.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ReviewAction } from '../../../entities/reviewAction/reviewAction.js';
|
|
2
|
+
import type { ReviewActionGateway, ExecutionContext } from '../../../entities/reviewAction/reviewAction.gateway.js';
|
|
3
|
+
import { ExecutionGatewayBase, type CommandInfo } from '../../../shared/foundation/executionGateway.base.js';
|
|
4
|
+
export declare class GitHubReviewActionCliGateway extends ExecutionGatewayBase<ReviewAction, ExecutionContext> implements ReviewActionGateway {
|
|
5
|
+
protected buildCommand(action: ReviewAction, context: ExecutionContext): CommandInfo | null;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=reviewAction.github.cli.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewAction.github.cli.gateway.d.ts","sourceRoot":"","sources":["../../../../src/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gDAAgD,CAAA;AAClF,OAAO,KAAK,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,wDAAwD,CAAA;AACnH,OAAO,EAAE,oBAAoB,EAAE,KAAK,WAAW,EAAE,MAAM,qDAAqD,CAAA;AAE5G,qBAAa,4BACX,SAAQ,oBAAoB,CAAC,YAAY,EAAE,gBAAgB,CAC3D,YAAW,mBAAmB;IAE9B,SAAS,CAAC,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,gBAAgB,GAAG,WAAW,GAAG,IAAI;CAuE5F"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { ExecutionGatewayBase } from '../../../shared/foundation/executionGateway.base.js';
|
|
2
|
+
export class GitHubReviewActionCliGateway extends ExecutionGatewayBase {
|
|
3
|
+
buildCommand(action, context) {
|
|
4
|
+
switch (action.type) {
|
|
5
|
+
case 'THREAD_RESOLVE':
|
|
6
|
+
return {
|
|
7
|
+
command: 'gh',
|
|
8
|
+
args: [
|
|
9
|
+
'api',
|
|
10
|
+
'graphql',
|
|
11
|
+
'-f',
|
|
12
|
+
`query=mutation { resolveReviewThread(input: {threadId: "${action.threadId}"}) { thread { id isResolved } } }`,
|
|
13
|
+
],
|
|
14
|
+
};
|
|
15
|
+
case 'POST_COMMENT':
|
|
16
|
+
return {
|
|
17
|
+
command: 'gh',
|
|
18
|
+
args: [
|
|
19
|
+
'api',
|
|
20
|
+
'--method',
|
|
21
|
+
'POST',
|
|
22
|
+
`repos/${context.projectPath}/issues/${context.mrNumber}/comments`,
|
|
23
|
+
'--field',
|
|
24
|
+
`body=${action.body}`,
|
|
25
|
+
],
|
|
26
|
+
};
|
|
27
|
+
case 'THREAD_REPLY':
|
|
28
|
+
return {
|
|
29
|
+
command: 'gh',
|
|
30
|
+
args: [
|
|
31
|
+
'api',
|
|
32
|
+
'--method',
|
|
33
|
+
'POST',
|
|
34
|
+
`repos/${context.projectPath}/pulls/${context.mrNumber}/comments/${action.threadId}/replies`,
|
|
35
|
+
'--field',
|
|
36
|
+
`body=${action.message}`,
|
|
37
|
+
],
|
|
38
|
+
};
|
|
39
|
+
case 'ADD_LABEL':
|
|
40
|
+
return {
|
|
41
|
+
command: 'gh',
|
|
42
|
+
args: [
|
|
43
|
+
'api',
|
|
44
|
+
'--method',
|
|
45
|
+
'POST',
|
|
46
|
+
`repos/${context.projectPath}/issues/${context.mrNumber}/labels`,
|
|
47
|
+
'--field',
|
|
48
|
+
`labels[]=${action.label}`,
|
|
49
|
+
],
|
|
50
|
+
};
|
|
51
|
+
case 'POST_INLINE_COMMENT': {
|
|
52
|
+
if (!context.diffMetadata)
|
|
53
|
+
return null;
|
|
54
|
+
return {
|
|
55
|
+
command: 'gh',
|
|
56
|
+
args: [
|
|
57
|
+
'api', '--method', 'POST',
|
|
58
|
+
`repos/${context.projectPath}/pulls/${context.mrNumber}/comments`,
|
|
59
|
+
'--field', `body=${action.body}`,
|
|
60
|
+
'--field', `commit_id=${context.diffMetadata.headSha}`,
|
|
61
|
+
'--field', `path=${action.filePath}`,
|
|
62
|
+
'--field', `line=${action.line}`,
|
|
63
|
+
],
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
case 'FETCH_THREADS':
|
|
67
|
+
return null;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=reviewAction.github.cli.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewAction.github.cli.gateway.js","sourceRoot":"","sources":["../../../../src/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAoB,MAAM,qDAAqD,CAAA;AAE5G,MAAM,OAAO,4BACX,SAAQ,oBAAoD;IAGlD,YAAY,CAAC,MAAoB,EAAE,OAAyB;QACpE,QAAQ,MAAM,CAAC,IAAI,EAAE,CAAC;YACpB,KAAK,gBAAgB;gBACnB,OAAO;oBACL,OAAO,EAAE,IAAI;oBACb,IAAI,EAAE;wBACJ,KAAK;wBACL,SAAS;wBACT,IAAI;wBACJ,2DAA2D,MAAM,CAAC,QAAQ,oCAAoC;qBAC/G;iBACF,CAAA;YAEH,KAAK,cAAc;gBACjB,OAAO;oBACL,OAAO,EAAE,IAAI;oBACb,IAAI,EAAE;wBACJ,KAAK;wBACL,UAAU;wBACV,MAAM;wBACN,SAAS,OAAO,CAAC,WAAW,WAAW,OAAO,CAAC,QAAQ,WAAW;wBAClE,SAAS;wBACT,QAAQ,MAAM,CAAC,IAAI,EAAE;qBACtB;iBACF,CAAA;YAEH,KAAK,cAAc;gBACjB,OAAO;oBACL,OAAO,EAAE,IAAI;oBACb,IAAI,EAAE;wBACJ,KAAK;wBACL,UAAU;wBACV,MAAM;wBACN,SAAS,OAAO,CAAC,WAAW,UAAU,OAAO,CAAC,QAAQ,aAAa,MAAM,CAAC,QAAQ,UAAU;wBAC5F,SAAS;wBACT,QAAQ,MAAM,CAAC,OAAO,EAAE;qBACzB;iBACF,CAAA;YAEH,KAAK,WAAW;gBACd,OAAO;oBACL,OAAO,EAAE,IAAI;oBACb,IAAI,EAAE;wBACJ,KAAK;wBACL,UAAU;wBACV,MAAM;wBACN,SAAS,OAAO,CAAC,WAAW,WAAW,OAAO,CAAC,QAAQ,SAAS;wBAChE,SAAS;wBACT,YAAY,MAAM,CAAC,KAAK,EAAE;qBAC3B;iBACF,CAAA;YAEH,KAAK,qBAAqB,CAAC,CAAC,CAAC;gBAC3B,IAAI,CAAC,OAAO,CAAC,YAAY;oBAAE,OAAO,IAAI,CAAA;gBACtC,OAAO;oBACL,OAAO,EAAE,IAAI;oBACb,IAAI,EAAE;wBACJ,KAAK,EAAE,UAAU,EAAE,MAAM;wBACzB,SAAS,OAAO,CAAC,WAAW,UAAU,OAAO,CAAC,QAAQ,WAAW;wBACjE,SAAS,EAAE,QAAQ,MAAM,CAAC,IAAI,EAAE;wBAChC,SAAS,EAAE,aAAa,OAAO,CAAC,YAAY,CAAC,OAAO,EAAE;wBACtD,SAAS,EAAE,QAAQ,MAAM,CAAC,QAAQ,EAAE;wBACpC,SAAS,EAAE,QAAQ,MAAM,CAAC,IAAI,EAAE;qBACjC;iBACF,CAAA;YACH,CAAC;YAED,KAAK,eAAe;gBAClB,OAAO,IAAI,CAAA;QACf,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ReviewAction } from '../../../entities/reviewAction/reviewAction.js';
|
|
2
|
+
import type { ReviewActionGateway, ExecutionContext } from '../../../entities/reviewAction/reviewAction.gateway.js';
|
|
3
|
+
import { ExecutionGatewayBase, type CommandInfo } from '../../../shared/foundation/executionGateway.base.js';
|
|
4
|
+
export declare class GitLabReviewActionCliGateway extends ExecutionGatewayBase<ReviewAction, ExecutionContext> implements ReviewActionGateway {
|
|
5
|
+
protected buildCommand(action: ReviewAction, context: ExecutionContext): CommandInfo | null;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=reviewAction.gitlab.cli.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewAction.gitlab.cli.gateway.d.ts","sourceRoot":"","sources":["../../../../src/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gDAAgD,CAAA;AAClF,OAAO,KAAK,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,wDAAwD,CAAA;AACnH,OAAO,EAAE,oBAAoB,EAAE,KAAK,WAAW,EAAE,MAAM,qDAAqD,CAAA;AAE5G,qBAAa,4BACX,SAAQ,oBAAoB,CAAC,YAAY,EAAE,gBAAgB,CAC3D,YAAW,mBAAmB;IAE9B,SAAS,CAAC,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,gBAAgB,GAAG,WAAW,GAAG,IAAI;CA2D5F"}
|