reviewflow 3.12.0 → 3.14.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 +20 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts +31 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -1
- package/dist/frameworks/claude/claudeInvoker.js +243 -288
- package/dist/frameworks/claude/claudeInvoker.js.map +1 -1
- package/dist/frameworks/claude/streamJsonParser.d.ts +1 -38
- package/dist/frameworks/claude/streamJsonParser.d.ts.map +1 -1
- package/dist/frameworks/claude/streamJsonParser.js +16 -88
- package/dist/frameworks/claude/streamJsonParser.js.map +1 -1
- package/dist/frameworks/claude/timers/claudeInvocationTimers.d.ts +14 -0
- package/dist/frameworks/claude/timers/claudeInvocationTimers.d.ts.map +1 -0
- package/dist/frameworks/claude/timers/claudeInvocationTimers.js +23 -0
- package/dist/frameworks/claude/timers/claudeInvocationTimers.js.map +1 -0
- package/dist/frameworks/queue/pQueueAdapter.d.ts +2 -0
- package/dist/frameworks/queue/pQueueAdapter.d.ts.map +1 -1
- package/dist/frameworks/queue/pQueueAdapter.js +26 -5
- package/dist/frameworks/queue/pQueueAdapter.js.map +1 -1
- package/dist/frameworks/scheduler/supervisorScheduler.d.ts +17 -0
- package/dist/frameworks/scheduler/supervisorScheduler.d.ts.map +1 -0
- package/dist/frameworks/scheduler/supervisorScheduler.js +25 -0
- package/dist/frameworks/scheduler/supervisorScheduler.js.map +1 -0
- package/dist/main/dependencies.d.ts +4 -0
- package/dist/main/dependencies.d.ts.map +1 -1
- package/dist/main/dependencies.js +4 -0
- package/dist/main/dependencies.js.map +1 -1
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +14 -0
- package/dist/main/routes.js.map +1 -1
- package/dist/main/server.d.ts.map +1 -1
- package/dist/main/server.js +37 -0
- package/dist/main/server.js.map +1 -1
- package/dist/mcp/mcpServerStdio.d.ts.map +1 -1
- package/dist/mcp/mcpServerStdio.js +10 -1
- package/dist/mcp/mcpServerStdio.js.map +1 -1
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.js +7 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.d.ts +4 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.d.ts +16 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.d.ts +52 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.d.ts +11 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.js +4 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.js +29 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts +38 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js +27 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.d.ts +10 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.js +14 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.d.ts +10 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.js +11 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.d.ts +16 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.js +7 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.d.ts +28 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.js +9 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.d.ts +6 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.d.ts +16 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.js +8 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.d.ts +10 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.js +32 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.d.ts +25 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.js +102 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.js +11 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.d.ts +34 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.js +131 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.d.ts +10 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.js +24 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.d.ts +12 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.js +25 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.js +18 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.d.ts +15 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.js +12 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.d.ts +16 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.js +64 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.d.ts +10 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.js +12 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.d.ts +15 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.js +25 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.d.ts +34 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.js +32 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.d.ts +20 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.js +17 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.d.ts +41 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.js +88 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.js.map +1 -0
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/health.routes.d.ts +2 -0
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/health.routes.d.ts.map +1 -1
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/health.routes.js +16 -1
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/health.routes.js.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.d.ts +6 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js +16 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts +6 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js +31 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.d.ts +2 -0
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.d.ts.map +1 -1
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.js +4 -1
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.js.map +1 -1
- package/dist/modules/supervisor-management/entities/supervisor/supervisor.gateway.d.ts +14 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisor.gateway.d.ts.map +1 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisor.gateway.js +2 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisor.gateway.js.map +1 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorLock.gateway.d.ts +9 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorLock.gateway.d.ts.map +1 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorLock.gateway.js +2 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorLock.gateway.js.map +1 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatus.schema.d.ts +19 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatus.schema.d.ts.map +1 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatus.schema.js +11 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatus.schema.js.map +1 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatusStore.gateway.d.ts +6 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatusStore.gateway.d.ts.map +1 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatusStore.gateway.js +2 -0
- package/dist/modules/supervisor-management/entities/supervisor/supervisorStatusStore.gateway.js.map +1 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisor.cli.gateway.d.ts +25 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisor.cli.gateway.d.ts.map +1 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisor.cli.gateway.js +79 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisor.cli.gateway.js.map +1 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorLock.fileSystem.gateway.d.ts +22 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorLock.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorLock.fileSystem.gateway.js +71 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorLock.fileSystem.gateway.js.map +1 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorStatusStore.memory.gateway.d.ts +8 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorStatusStore.memory.gateway.d.ts.map +1 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorStatusStore.memory.gateway.js +20 -0
- package/dist/modules/supervisor-management/interface-adapters/gateways/supervisorStatusStore.memory.gateway.js.map +1 -0
- package/dist/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.d.ts +14 -0
- package/dist/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.d.ts.map +1 -0
- package/dist/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.js +51 -0
- package/dist/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.js.map +1 -0
- package/dist/modules/worktree-management/entities/gitCommand/gitCommand.gateway.d.ts +15 -0
- package/dist/modules/worktree-management/entities/gitCommand/gitCommand.gateway.d.ts.map +1 -0
- package/dist/modules/worktree-management/entities/gitCommand/gitCommand.gateway.js +2 -0
- package/dist/modules/worktree-management/entities/gitCommand/gitCommand.gateway.js.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.d.ts +14 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.d.ts.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.gateway.d.ts +18 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.gateway.d.ts.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.gateway.js +2 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.gateway.js.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.js +58 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.js.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.schema.d.ts +54 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.schema.d.ts.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.schema.js +8 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.schema.js.map +1 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.d.ts +8 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.d.ts.map +1 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.js +28 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.js.map +1 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.d.ts +17 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.js +67 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.js.map +1 -0
- package/dist/modules/worktree-management/services/worktreeSettingsWriter.d.ts +4 -0
- package/dist/modules/worktree-management/services/worktreeSettingsWriter.d.ts.map +1 -0
- package/dist/modules/worktree-management/services/worktreeSettingsWriter.js +16 -0
- package/dist/modules/worktree-management/services/worktreeSettingsWriter.js.map +1 -0
- package/dist/modules/worktree-management/usecases/ensureWorktree.usecase.d.ts +19 -0
- package/dist/modules/worktree-management/usecases/ensureWorktree.usecase.d.ts.map +1 -0
- package/dist/modules/worktree-management/usecases/ensureWorktree.usecase.js +53 -0
- package/dist/modules/worktree-management/usecases/ensureWorktree.usecase.js.map +1 -0
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.d.ts +12 -0
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.d.ts.map +1 -0
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.js +26 -0
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.js.map +1 -0
- package/dist/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.d.ts +23 -0
- package/dist/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.d.ts.map +1 -0
- package/dist/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.js +63 -0
- package/dist/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.js.map +1 -0
- package/dist/shared/services/daemonPaths.d.ts +1 -0
- package/dist/shared/services/daemonPaths.d.ts.map +1 -1
- package/dist/shared/services/daemonPaths.js +1 -0
- package/dist/shared/services/daemonPaths.js.map +1 -1
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.d.ts +2 -0
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.js +238 -0
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.js.map +1 -0
- package/dist/tests/acceptance/170-prebuilt-worktree-lifecycle.acceptance.test.d.ts +13 -0
- package/dist/tests/acceptance/170-prebuilt-worktree-lifecycle.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/170-prebuilt-worktree-lifecycle.acceptance.test.js +145 -0
- package/dist/tests/acceptance/170-prebuilt-worktree-lifecycle.acceptance.test.js.map +1 -0
- package/dist/tests/acceptance/172-claude-agents-supervisor-lifecycle.acceptance.test.d.ts +2 -0
- package/dist/tests/acceptance/172-claude-agents-supervisor-lifecycle.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/172-claude-agents-supervisor-lifecycle.acceptance.test.js +118 -0
- package/dist/tests/acceptance/172-claude-agents-supervisor-lifecycle.acceptance.test.js.map +1 -0
- package/dist/tests/acceptance/46-github-followup-review-on-push.acceptance.test.js +5 -34
- package/dist/tests/acceptance/46-github-followup-review-on-push.acceptance.test.js.map +1 -1
- package/dist/tests/factories/claudeSession.factory.d.ts +5 -0
- package/dist/tests/factories/claudeSession.factory.d.ts.map +1 -0
- package/dist/tests/factories/claudeSession.factory.js +17 -0
- package/dist/tests/factories/claudeSession.factory.js.map +1 -0
- package/dist/tests/factories/sessionCompletion.factory.d.ts +5 -0
- package/dist/tests/factories/sessionCompletion.factory.d.ts.map +1 -0
- package/dist/tests/factories/sessionCompletion.factory.js +11 -0
- package/dist/tests/factories/sessionCompletion.factory.js.map +1 -0
- package/dist/tests/integration/claudeInvocation.integration.test.d.ts +2 -0
- package/dist/tests/integration/claudeInvocation.integration.test.d.ts.map +1 -0
- package/dist/tests/integration/claudeInvocation.integration.test.js +147 -0
- package/dist/tests/integration/claudeInvocation.integration.test.js.map +1 -0
- package/dist/tests/stubs/billingState.stub.d.ts +10 -0
- package/dist/tests/stubs/billingState.stub.d.ts.map +1 -0
- package/dist/tests/stubs/billingState.stub.js +32 -0
- package/dist/tests/stubs/billingState.stub.js.map +1 -0
- package/dist/tests/stubs/capturingLogger.stub.d.ts +9 -0
- package/dist/tests/stubs/capturingLogger.stub.d.ts.map +1 -0
- package/dist/tests/stubs/capturingLogger.stub.js +36 -0
- package/dist/tests/stubs/capturingLogger.stub.js.map +1 -0
- package/dist/tests/stubs/claudeSession.stub.d.ts +23 -0
- package/dist/tests/stubs/claudeSession.stub.d.ts.map +1 -0
- package/dist/tests/stubs/claudeSession.stub.js +55 -0
- package/dist/tests/stubs/claudeSession.stub.js.map +1 -0
- package/dist/tests/stubs/environment.stub.d.ts +7 -0
- package/dist/tests/stubs/environment.stub.d.ts.map +1 -0
- package/dist/tests/stubs/environment.stub.js +10 -0
- package/dist/tests/stubs/environment.stub.js.map +1 -0
- package/dist/tests/stubs/gitCommandExecutor.stub.d.ts +13 -0
- package/dist/tests/stubs/gitCommandExecutor.stub.d.ts.map +1 -0
- package/dist/tests/stubs/gitCommandExecutor.stub.js +25 -0
- package/dist/tests/stubs/gitCommandExecutor.stub.js.map +1 -0
- package/dist/tests/stubs/mcpCompletion.stub.d.ts +13 -0
- package/dist/tests/stubs/mcpCompletion.stub.d.ts.map +1 -0
- package/dist/tests/stubs/mcpCompletion.stub.js +29 -0
- package/dist/tests/stubs/mcpCompletion.stub.js.map +1 -0
- package/dist/tests/stubs/reviewReport.stub.d.ts +11 -0
- package/dist/tests/stubs/reviewReport.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewReport.stub.js +21 -0
- package/dist/tests/stubs/reviewReport.stub.js.map +1 -0
- package/dist/tests/stubs/supervisor.stub.d.ts +12 -0
- package/dist/tests/stubs/supervisor.stub.d.ts.map +1 -0
- package/dist/tests/stubs/supervisor.stub.js +25 -0
- package/dist/tests/stubs/supervisor.stub.js.map +1 -0
- package/dist/tests/stubs/supervisorHealth.stub.d.ts +8 -0
- package/dist/tests/stubs/supervisorHealth.stub.d.ts.map +1 -0
- package/dist/tests/stubs/supervisorHealth.stub.js +18 -0
- package/dist/tests/stubs/supervisorHealth.stub.js.map +1 -0
- package/dist/tests/stubs/supervisorLock.stub.d.ts +10 -0
- package/dist/tests/stubs/supervisorLock.stub.d.ts.map +1 -0
- package/dist/tests/stubs/supervisorLock.stub.js +19 -0
- package/dist/tests/stubs/supervisorLock.stub.js.map +1 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.d.ts +2 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.d.ts.map +1 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.js +89 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.js.map +1 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.d.ts +2 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.js +30 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.js.map +1 -0
- package/dist/tests/units/frameworks/claude/claudeInvoker.test.js +24 -27
- package/dist/tests/units/frameworks/claude/claudeInvoker.test.js.map +1 -1
- package/dist/tests/units/frameworks/claude/mcpContext.test.js +3 -1
- package/dist/tests/units/frameworks/claude/mcpContext.test.js.map +1 -1
- package/dist/tests/units/frameworks/claude/streamJsonParser.test.js +15 -72
- package/dist/tests/units/frameworks/claude/streamJsonParser.test.js.map +1 -1
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.d.ts +2 -0
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.js +66 -0
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.js.map +1 -0
- package/dist/tests/units/frameworks/queue/pQueueAdapter.test.d.ts +2 -0
- package/dist/tests/units/frameworks/queue/pQueueAdapter.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/queue/pQueueAdapter.test.js +116 -0
- package/dist/tests/units/frameworks/queue/pQueueAdapter.test.js.map +1 -0
- package/dist/tests/units/frameworks/scheduler/supervisorScheduler.test.d.ts +2 -0
- package/dist/tests/units/frameworks/scheduler/supervisorScheduler.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/scheduler/supervisorScheduler.test.js +76 -0
- package/dist/tests/units/frameworks/scheduler/supervisorScheduler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js +45 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js +27 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +43 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.js +51 -0
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.js +28 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.js +27 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.js +40 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.js +188 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.js +17 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.js +119 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.js +39 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.js +64 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.js +32 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.js +33 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.js +53 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.js +31 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.js +17 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.js +97 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.js +49 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.js +171 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/supervisor-management/entities/supervisorStatus.schema.test.d.ts +2 -0
- package/dist/tests/units/modules/supervisor-management/entities/supervisorStatus.schema.test.d.ts.map +1 -0
- package/dist/tests/units/modules/supervisor-management/entities/supervisorStatus.schema.test.js +32 -0
- package/dist/tests/units/modules/supervisor-management/entities/supervisorStatus.schema.test.js.map +1 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisor.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisor.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisor.cli.gateway.test.js +85 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisor.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorLock.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorLock.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorLock.fileSystem.gateway.test.js +94 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorLock.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorStatusStore.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorStatusStore.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorStatusStore.memory.gateway.test.js +26 -0
- package/dist/tests/units/modules/supervisor-management/gateways/supervisorStatusStore.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.test.js +129 -0
- package/dist/tests/units/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktree.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktree.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktree.test.js +54 -0
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktree.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.test.js +35 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/services/worktreeSettingsWriter.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/services/worktreeSettingsWriter.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/services/worktreeSettingsWriter.test.js +32 -0
- package/dist/tests/units/modules/worktree-management/services/worktreeSettingsWriter.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/ensureWorktree.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/usecases/ensureWorktree.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/ensureWorktree.usecase.test.js +113 -0
- package/dist/tests/units/modules/worktree-management/usecases/ensureWorktree.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/removeWorktree.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/usecases/removeWorktree.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/removeWorktree.usecase.test.js +55 -0
- package/dist/tests/units/modules/worktree-management/usecases/removeWorktree.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.test.js +131 -0
- package/dist/tests/units/modules/worktree-management/usecases/sweepStaleWorktrees.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js +21 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { ReviewReportContent, ReviewReportGateway, ReviewReportLocation } from '../../../../modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js';
|
|
2
|
+
export interface ReviewReportFileSystem {
|
|
3
|
+
existsSync: (path: string) => boolean;
|
|
4
|
+
readFileSync: (path: string) => string;
|
|
5
|
+
}
|
|
6
|
+
export declare class ReviewReportFileSystemGateway implements ReviewReportGateway {
|
|
7
|
+
private readonly fs;
|
|
8
|
+
constructor(fs?: ReviewReportFileSystem);
|
|
9
|
+
buildPath(location: ReviewReportLocation): string;
|
|
10
|
+
read(location: ReviewReportLocation): ReviewReportContent | null;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=reviewReport.fileSystem.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewReport.fileSystem.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,gFAAgF,CAAC;AAExF,MAAM,WAAW,sBAAsB;IACrC,UAAU,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACtC,YAAY,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,CAAC;CACxC;AAOD,qBAAa,6BAA8B,YAAW,mBAAmB;IAC3D,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,GAAE,sBAAkC;IAEnE,SAAS,CAAC,QAAQ,EAAE,oBAAoB,GAAG,MAAM;IAMjD,IAAI,CAAC,QAAQ,EAAE,oBAAoB,GAAG,mBAAmB,GAAG,IAAI;CAOjE"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { existsSync, readFileSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
const defaultFs = {
|
|
4
|
+
existsSync,
|
|
5
|
+
readFileSync: (path) => readFileSync(path, 'utf-8'),
|
|
6
|
+
};
|
|
7
|
+
export class ReviewReportFileSystemGateway {
|
|
8
|
+
fs;
|
|
9
|
+
constructor(fs = defaultFs) {
|
|
10
|
+
this.fs = fs;
|
|
11
|
+
}
|
|
12
|
+
buildPath(location) {
|
|
13
|
+
const suffix = location.jobType === 'followup' ? 'followup' : 'review';
|
|
14
|
+
const fileName = `${location.isoDate}-MR-${location.mergeRequestNumber}-${suffix}.md`;
|
|
15
|
+
return join(location.localPath, '.claude', 'reviews', fileName);
|
|
16
|
+
}
|
|
17
|
+
read(location) {
|
|
18
|
+
const path = this.buildPath(location);
|
|
19
|
+
if (!this.fs.existsSync(path)) {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
return { content: this.fs.readFileSync(path), path };
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=reviewReport.fileSystem.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reviewReport.fileSystem.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAYjC,MAAM,SAAS,GAA2B;IACxC,UAAU;IACV,YAAY,EAAE,CAAC,IAAY,EAAE,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC;CAC5D,CAAC;AAEF,MAAM,OAAO,6BAA6B;IACX;IAA7B,YAA6B,KAA6B,SAAS;QAAtC,OAAE,GAAF,EAAE,CAAoC;IAAG,CAAC;IAEvE,SAAS,CAAC,QAA8B;QACtC,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,KAAK,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC;QACvE,MAAM,QAAQ,GAAG,GAAG,QAAQ,CAAC,OAAO,OAAO,QAAQ,CAAC,kBAAkB,IAAI,MAAM,KAAK,CAAC;QACtF,OAAO,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;IAClE,CAAC;IAED,IAAI,CAAC,QAA8B;QACjC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC;IACvD,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SupervisorHealth, SupervisorHealthStatus } from '../../../../modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.js';
|
|
2
|
+
import type { SupervisorHealthGateway } from '../../../../modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.js';
|
|
3
|
+
export declare class InMemorySupervisorHealthGateway implements SupervisorHealthGateway {
|
|
4
|
+
private state;
|
|
5
|
+
read(): SupervisorHealth;
|
|
6
|
+
update(status: SupervisorHealthStatus, reason: string | null, checkedAt: string): void;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=supervisorHealth.memory.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supervisorHealth.memory.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,gBAAgB,EAChB,sBAAsB,EACvB,MAAM,kFAAkF,CAAC;AAC1F,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,mFAAmF,CAAC;AAEjI,qBAAa,+BAAgC,YAAW,uBAAuB;IAC7E,OAAO,CAAC,KAAK,CAIX;IAEF,IAAI,IAAI,gBAAgB;IAIxB,MAAM,CAAC,MAAM,EAAE,sBAAsB,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;CAOvF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export class InMemorySupervisorHealthGateway {
|
|
2
|
+
state = {
|
|
3
|
+
status: 'up',
|
|
4
|
+
lastCheckAt: null,
|
|
5
|
+
lastDownReason: null,
|
|
6
|
+
};
|
|
7
|
+
read() {
|
|
8
|
+
return { ...this.state };
|
|
9
|
+
}
|
|
10
|
+
update(status, reason, checkedAt) {
|
|
11
|
+
this.state = {
|
|
12
|
+
status,
|
|
13
|
+
lastCheckAt: checkedAt,
|
|
14
|
+
lastDownReason: status === 'down' ? reason : null,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=supervisorHealth.memory.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supervisorHealth.memory.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.ts"],"names":[],"mappings":"AAMA,MAAM,OAAO,+BAA+B;IAClC,KAAK,GAAqB;QAChC,MAAM,EAAE,IAAI;QACZ,WAAW,EAAE,IAAI;QACjB,cAAc,EAAE,IAAI;KACrB,CAAC;IAEF,IAAI;QACF,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,MAAM,CAAC,MAA8B,EAAE,MAAqB,EAAE,SAAiB;QAC7E,IAAI,CAAC,KAAK,GAAG;YACX,MAAM;YACN,WAAW,EAAE,SAAS;YACtB,cAAc,EAAE,MAAM,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI;SAClD,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { BillingStateGateway } from '../../../modules/claude-invocation/entities/billingState/billingState.gateway.js';
|
|
2
|
+
import type { ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
3
|
+
export interface AuditBillingDependencies {
|
|
4
|
+
sessionGateway: ClaudeSessionGateway;
|
|
5
|
+
billingStateGateway: BillingStateGateway;
|
|
6
|
+
now: () => Date;
|
|
7
|
+
}
|
|
8
|
+
export type AuditBillingResult = {
|
|
9
|
+
regression: false;
|
|
10
|
+
} | {
|
|
11
|
+
regression: true;
|
|
12
|
+
reason: string;
|
|
13
|
+
};
|
|
14
|
+
export declare function auditBilling(deps: AuditBillingDependencies): Promise<AuditBillingResult>;
|
|
15
|
+
//# sourceMappingURL=auditBilling.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auditBilling.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/auditBilling.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2EAA2E,CAAC;AACrH,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AAExH,MAAM,WAAW,wBAAwB;IACvC,cAAc,EAAE,oBAAoB,CAAC;IACrC,mBAAmB,EAAE,mBAAmB,CAAC;IACzC,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAED,MAAM,MAAM,kBAAkB,GAC1B;IAAE,UAAU,EAAE,KAAK,CAAA;CAAE,GACrB;IAAE,UAAU,EAAE,IAAI,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AAEzC,wBAAsB,YAAY,CAChC,IAAI,EAAE,wBAAwB,GAC7B,OAAO,CAAC,kBAAkB,CAAC,CAY7B"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export async function auditBilling(deps) {
|
|
2
|
+
const report = await deps.sessionGateway.usage();
|
|
3
|
+
const auditedAt = deps.now().toISOString();
|
|
4
|
+
if (report.usesApiPool) {
|
|
5
|
+
const reason = `API pool consumption detected: ${report.raw}`;
|
|
6
|
+
deps.billingStateGateway.pause(reason, auditedAt);
|
|
7
|
+
return { regression: true, reason };
|
|
8
|
+
}
|
|
9
|
+
deps.billingStateGateway.recordHealthy(auditedAt);
|
|
10
|
+
return { regression: false };
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=auditBilling.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auditBilling.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/auditBilling.usecase.ts"],"names":[],"mappings":"AAaA,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,IAA8B;IAE9B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;IACjD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;IAE3C,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;QACvB,MAAM,MAAM,GAAG,kCAAkC,MAAM,CAAC,GAAG,EAAE,CAAC;QAC9D,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAClD,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;IACtC,CAAC;IAED,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IAClD,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC;AAC/B,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { McpCompletionBridge } from '../../../modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js';
|
|
2
|
+
import type { ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
3
|
+
import type { ClaudeSession } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
4
|
+
import type { SessionCompletion } from '../../../modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.js';
|
|
5
|
+
export interface AwaitSessionCompletionInput {
|
|
6
|
+
session: ClaudeSession;
|
|
7
|
+
timeoutMs: number;
|
|
8
|
+
pollIntervalMs: number;
|
|
9
|
+
}
|
|
10
|
+
export interface AwaitSessionCompletionDependencies {
|
|
11
|
+
sessionGateway: ClaudeSessionGateway;
|
|
12
|
+
completionBridge: McpCompletionBridge;
|
|
13
|
+
now: () => Date;
|
|
14
|
+
}
|
|
15
|
+
export declare function awaitSessionCompletion(input: AwaitSessionCompletionInput, deps: AwaitSessionCompletionDependencies): Promise<SessionCompletion>;
|
|
16
|
+
//# sourceMappingURL=awaitSessionCompletion.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"awaitSessionCompletion.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iFAAiF,CAAC;AAC3H,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AACxH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4EAA4E,CAAC;AAChH,OAAO,KAAK,EACV,iBAAiB,EAElB,MAAM,oFAAoF,CAAC;AAG5F,MAAM,WAAW,2BAA2B;IAC1C,OAAO,EAAE,aAAa,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,kCAAkC;IACjD,cAAc,EAAE,oBAAoB,CAAC;IACrC,gBAAgB,EAAE,mBAAmB,CAAC;IACtC,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAUD,wBAAgB,sBAAsB,CACpC,KAAK,EAAE,2BAA2B,EAClC,IAAI,EAAE,kCAAkC,GACvC,OAAO,CAAC,iBAAiB,CAAC,CAuD5B"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { isExpired } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.js';
|
|
2
|
+
const TERMINAL_AGENT_STATUSES = new Set(['completed', 'failed', 'stopped']);
|
|
3
|
+
function agentStatusToOutcome(status) {
|
|
4
|
+
if (status === 'completed')
|
|
5
|
+
return 'completed';
|
|
6
|
+
if (status === 'stopped')
|
|
7
|
+
return 'stopped';
|
|
8
|
+
return 'failed';
|
|
9
|
+
}
|
|
10
|
+
export function awaitSessionCompletion(input, deps) {
|
|
11
|
+
const { session, timeoutMs, pollIntervalMs } = input;
|
|
12
|
+
const { sessionGateway, completionBridge, now } = deps;
|
|
13
|
+
return new Promise(resolve => {
|
|
14
|
+
let settled = false;
|
|
15
|
+
let pollTimer = null;
|
|
16
|
+
const cleanup = () => {
|
|
17
|
+
completionBridge.unsubscribe(session.jobId);
|
|
18
|
+
if (pollTimer !== null)
|
|
19
|
+
clearTimeout(pollTimer);
|
|
20
|
+
};
|
|
21
|
+
const settle = (completion) => {
|
|
22
|
+
if (settled)
|
|
23
|
+
return;
|
|
24
|
+
settled = true;
|
|
25
|
+
cleanup();
|
|
26
|
+
resolve(completion);
|
|
27
|
+
};
|
|
28
|
+
completionBridge.subscribe(session.jobId, completion => {
|
|
29
|
+
settle({ ...completion, source: completion.source });
|
|
30
|
+
});
|
|
31
|
+
const tick = async () => {
|
|
32
|
+
if (settled)
|
|
33
|
+
return;
|
|
34
|
+
if (isExpired(session, now(), timeoutMs)) {
|
|
35
|
+
settle({ source: 'timeout', outcome: 'failed', reason: 'timeout' });
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
try {
|
|
39
|
+
const agents = await sessionGateway.listAgents();
|
|
40
|
+
const entry = agents.find(item => item.sessionId === session.sessionId);
|
|
41
|
+
if (entry && TERMINAL_AGENT_STATUSES.has(entry.status)) {
|
|
42
|
+
settle({
|
|
43
|
+
source: 'polling',
|
|
44
|
+
outcome: agentStatusToOutcome(entry.status),
|
|
45
|
+
reason: null,
|
|
46
|
+
});
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
catch {
|
|
51
|
+
// polling errors are non-fatal; retry on next tick
|
|
52
|
+
}
|
|
53
|
+
if (!settled) {
|
|
54
|
+
pollTimer = setTimeout(() => {
|
|
55
|
+
void tick();
|
|
56
|
+
}, pollIntervalMs);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
pollTimer = setTimeout(() => {
|
|
60
|
+
void tick();
|
|
61
|
+
}, pollIntervalMs);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=awaitSessionCompletion.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"awaitSessionCompletion.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,SAAS,EAAE,MAAM,qEAAqE,CAAC;AAchG,MAAM,uBAAuB,GAAG,IAAI,GAAG,CAAC,CAAC,WAAW,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;AAE5E,SAAS,oBAAoB,CAAC,MAAc;IAC1C,IAAI,MAAM,KAAK,WAAW;QAAE,OAAO,WAAW,CAAC;IAC/C,IAAI,MAAM,KAAK,SAAS;QAAE,OAAO,SAAS,CAAC;IAC3C,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,sBAAsB,CACpC,KAAkC,EAClC,IAAwC;IAExC,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,KAAK,CAAC;IACrD,MAAM,EAAE,cAAc,EAAE,gBAAgB,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;IAEvD,OAAO,IAAI,OAAO,CAAoB,OAAO,CAAC,EAAE;QAC9C,IAAI,OAAO,GAAG,KAAK,CAAC;QACpB,IAAI,SAAS,GAA0B,IAAI,CAAC;QAE5C,MAAM,OAAO,GAAG,GAAS,EAAE;YACzB,gBAAgB,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAC5C,IAAI,SAAS,KAAK,IAAI;gBAAE,YAAY,CAAC,SAAS,CAAC,CAAC;QAClD,CAAC,CAAC;QAEF,MAAM,MAAM,GAAG,CAAC,UAA6B,EAAQ,EAAE;YACrD,IAAI,OAAO;gBAAE,OAAO;YACpB,OAAO,GAAG,IAAI,CAAC;YACf,OAAO,EAAE,CAAC;YACV,OAAO,CAAC,UAAU,CAAC,CAAC;QACtB,CAAC,CAAC;QAEF,gBAAgB,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,CAAC,EAAE;YACrD,MAAM,CAAC,EAAE,GAAG,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,KAAK,IAAmB,EAAE;YACrC,IAAI,OAAO;gBAAE,OAAO;YACpB,IAAI,SAAS,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,SAAS,CAAC,EAAE,CAAC;gBACzC,MAAM,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC;gBACpE,OAAO;YACT,CAAC;YACD,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,UAAU,EAAE,CAAC;gBACjD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,OAAO,CAAC,SAAS,CAAC,CAAC;gBACxE,IAAI,KAAK,IAAI,uBAAuB,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;oBACvD,MAAM,CAAC;wBACL,MAAM,EAAE,SAAS;wBACjB,OAAO,EAAE,oBAAoB,CAAC,KAAK,CAAC,MAAM,CAAC;wBAC3C,MAAM,EAAE,IAAI;qBACb,CAAC,CAAC;oBACH,OAAO;gBACT,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,mDAAmD;YACrD,CAAC;YACD,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;oBAC1B,KAAK,IAAI,EAAE,CAAC;gBACd,CAAC,EAAE,cAAc,CAAC,CAAC;YACrB,CAAC;QACH,CAAC,CAAC;QAEF,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;YAC1B,KAAK,IAAI,EAAE,CAAC;QACd,CAAC,EAAE,cAAc,CAAC,CAAC;IACrB,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
2
|
+
import type { SupervisorHealthGateway } from '../../../modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.js';
|
|
3
|
+
import type { SupervisorHealth } from '../../../modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.js';
|
|
4
|
+
export interface CheckSupervisorHealthDependencies {
|
|
5
|
+
sessionGateway: ClaudeSessionGateway;
|
|
6
|
+
supervisorHealthGateway: SupervisorHealthGateway;
|
|
7
|
+
now: () => Date;
|
|
8
|
+
}
|
|
9
|
+
export declare function checkSupervisorHealth(deps: CheckSupervisorHealthDependencies): Promise<SupervisorHealth>;
|
|
10
|
+
//# sourceMappingURL=checkSupervisorHealth.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkSupervisorHealth.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AACxH,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,mFAAmF,CAAC;AACjI,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,kFAAkF,CAAC;AAEzH,MAAM,WAAW,iCAAiC;IAChD,cAAc,EAAE,oBAAoB,CAAC;IACrC,uBAAuB,EAAE,uBAAuB,CAAC;IACjD,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAED,wBAAsB,qBAAqB,CACzC,IAAI,EAAE,iCAAiC,GACtC,OAAO,CAAC,gBAAgB,CAAC,CAW3B"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export async function checkSupervisorHealth(deps) {
|
|
2
|
+
const status = await deps.sessionGateway.daemonStatus();
|
|
3
|
+
const checkedAt = deps.now().toISOString();
|
|
4
|
+
if (status.reachable) {
|
|
5
|
+
deps.supervisorHealthGateway.update('up', null, checkedAt);
|
|
6
|
+
}
|
|
7
|
+
else {
|
|
8
|
+
deps.supervisorHealthGateway.update('down', status.reason, checkedAt);
|
|
9
|
+
}
|
|
10
|
+
return deps.supervisorHealthGateway.read();
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=checkSupervisorHealth.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkSupervisorHealth.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.ts"],"names":[],"mappings":"AAUA,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,IAAuC;IAEvC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACxD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;IAE3C,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;QACrB,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;IAC7D,CAAC;SAAM,CAAC;QACN,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACxE,CAAC;IAED,OAAO,IAAI,CAAC,uBAAuB,CAAC,IAAI,EAAE,CAAC;AAC7C,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
2
|
+
import type { SessionId } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
3
|
+
export interface CleanupClaudeSessionInput {
|
|
4
|
+
sessionId: SessionId;
|
|
5
|
+
}
|
|
6
|
+
export interface CleanupClaudeSessionDependencies {
|
|
7
|
+
sessionGateway: ClaudeSessionGateway;
|
|
8
|
+
}
|
|
9
|
+
export interface CleanupClaudeSessionResult {
|
|
10
|
+
stopped: boolean;
|
|
11
|
+
removed: boolean;
|
|
12
|
+
warnings: string[];
|
|
13
|
+
}
|
|
14
|
+
export declare function cleanupClaudeSession(input: CleanupClaudeSessionInput, deps: CleanupClaudeSessionDependencies): Promise<CleanupClaudeSessionResult>;
|
|
15
|
+
//# sourceMappingURL=cleanupClaudeSession.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanupClaudeSession.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AACxH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,4EAA4E,CAAC;AAE5G,MAAM,WAAW,yBAAyB;IACxC,SAAS,EAAE,SAAS,CAAC;CACtB;AAED,MAAM,WAAW,gCAAgC;IAC/C,cAAc,EAAE,oBAAoB,CAAC;CACtC;AAED,MAAM,WAAW,0BAA0B;IACzC,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAED,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,yBAAyB,EAChC,IAAI,EAAE,gCAAgC,GACrC,OAAO,CAAC,0BAA0B,CAAC,CA0BrC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export async function cleanupClaudeSession(input, deps) {
|
|
2
|
+
const warnings = [];
|
|
3
|
+
const stopResult = await deps.sessionGateway.stop(input.sessionId).catch(error => {
|
|
4
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
5
|
+
warnings.push(`stop failed: ${message}`);
|
|
6
|
+
return { success: false, warning: message };
|
|
7
|
+
});
|
|
8
|
+
if (!stopResult.success && stopResult.warning) {
|
|
9
|
+
warnings.push(`stop: ${stopResult.warning}`);
|
|
10
|
+
}
|
|
11
|
+
const removeResult = await deps.sessionGateway.remove(input.sessionId).catch(error => {
|
|
12
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
13
|
+
warnings.push(`remove failed: ${message}`);
|
|
14
|
+
return { success: false, warning: message };
|
|
15
|
+
});
|
|
16
|
+
if (!removeResult.success && removeResult.warning) {
|
|
17
|
+
warnings.push(`remove: ${removeResult.warning}`);
|
|
18
|
+
}
|
|
19
|
+
return {
|
|
20
|
+
stopped: stopResult.success,
|
|
21
|
+
removed: removeResult.success,
|
|
22
|
+
warnings,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=cleanupClaudeSession.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanupClaudeSession.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.ts"],"names":[],"mappings":"AAiBA,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,KAAgC,EAChC,IAAsC;IAEtC,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;QAC/E,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACvE,QAAQ,CAAC,IAAI,CAAC,gBAAgB,OAAO,EAAE,CAAC,CAAC;QACzC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;IACH,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;QAC9C,QAAQ,CAAC,IAAI,CAAC,SAAS,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;QACnF,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACvE,QAAQ,CAAC,IAAI,CAAC,kBAAkB,OAAO,EAAE,CAAC,CAAC;QAC3C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;IACH,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;QAClD,QAAQ,CAAC,IAAI,CAAC,WAAW,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,OAAO;QACL,OAAO,EAAE,UAAU,CAAC,OAAO;QAC3B,OAAO,EAAE,YAAY,CAAC,OAAO;QAC7B,QAAQ;KACT,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { BillingStateGateway } from '../../../modules/claude-invocation/entities/billingState/billingState.gateway.js';
|
|
2
|
+
import type { EnvironmentGateway } from '../../../modules/claude-invocation/entities/billingState/environment.gateway.js';
|
|
3
|
+
import type { ClaudeDispatchFlags, ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
4
|
+
import type { ClaudeSession, ClaudeSessionJobType } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
5
|
+
export interface DispatchClaudeSessionInput {
|
|
6
|
+
jobId: string;
|
|
7
|
+
jobType: ClaudeSessionJobType;
|
|
8
|
+
prompt: string;
|
|
9
|
+
flags: ClaudeDispatchFlags;
|
|
10
|
+
localPath: string;
|
|
11
|
+
mergeRequestId: string;
|
|
12
|
+
}
|
|
13
|
+
export interface DispatchClaudeSessionDependencies {
|
|
14
|
+
sessionGateway: ClaudeSessionGateway;
|
|
15
|
+
environment: EnvironmentGateway;
|
|
16
|
+
billingState: BillingStateGateway;
|
|
17
|
+
now: () => Date;
|
|
18
|
+
}
|
|
19
|
+
export type DispatchClaudeSessionResult = {
|
|
20
|
+
status: 'dispatched';
|
|
21
|
+
session: ClaudeSession;
|
|
22
|
+
} | {
|
|
23
|
+
status: 'rate-limited';
|
|
24
|
+
rawStderr: string;
|
|
25
|
+
} | {
|
|
26
|
+
status: 'billing-regression-prevented';
|
|
27
|
+
} | {
|
|
28
|
+
status: 'paused';
|
|
29
|
+
} | {
|
|
30
|
+
status: 'failed';
|
|
31
|
+
rawStderr: string;
|
|
32
|
+
};
|
|
33
|
+
export declare function dispatchClaudeSession(input: DispatchClaudeSessionInput, deps: DispatchClaudeSessionDependencies): Promise<DispatchClaudeSessionResult>;
|
|
34
|
+
//# sourceMappingURL=dispatchClaudeSession.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dispatchClaudeSession.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2EAA2E,CAAC;AACrH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0EAA0E,CAAC;AACnH,OAAO,KAAK,EACV,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,6EAA6E,CAAC;AAIrF,OAAO,KAAK,EACV,aAAa,EACb,oBAAoB,EACrB,MAAM,4EAA4E,CAAC;AAEpF,MAAM,WAAW,0BAA0B;IACzC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,oBAAoB,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,mBAAmB,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,iCAAiC;IAChD,cAAc,EAAE,oBAAoB,CAAC;IACrC,WAAW,EAAE,kBAAkB,CAAC;IAChC,YAAY,EAAE,mBAAmB,CAAC;IAClC,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAED,MAAM,MAAM,2BAA2B,GACnC;IAAE,MAAM,EAAE,YAAY,CAAC;IAAC,OAAO,EAAE,aAAa,CAAA;CAAE,GAChD;IAAE,MAAM,EAAE,cAAc,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,GAC7C;IAAE,MAAM,EAAE,8BAA8B,CAAA;CAAE,GAC1C;IAAE,MAAM,EAAE,QAAQ,CAAA;CAAE,GACpB;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAC;AAE5C,wBAAsB,qBAAqB,CACzC,KAAK,EAAE,0BAA0B,EACjC,IAAI,EAAE,iCAAiC,GACtC,OAAO,CAAC,2BAA2B,CAAC,CAmCtC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { createClaudeSession, } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.js';
|
|
2
|
+
export async function dispatchClaudeSession(input, deps) {
|
|
3
|
+
if (deps.environment.hasAnthropicApiKey()) {
|
|
4
|
+
return { status: 'billing-regression-prevented' };
|
|
5
|
+
}
|
|
6
|
+
if (deps.billingState.read().dispatchPaused) {
|
|
7
|
+
return { status: 'paused' };
|
|
8
|
+
}
|
|
9
|
+
const result = await deps.sessionGateway.dispatch({
|
|
10
|
+
prompt: input.prompt,
|
|
11
|
+
flags: input.flags,
|
|
12
|
+
localPath: input.localPath,
|
|
13
|
+
jobId: input.jobId,
|
|
14
|
+
jobType: input.jobType,
|
|
15
|
+
});
|
|
16
|
+
if (result.status === 'rate-limited') {
|
|
17
|
+
return { status: 'rate-limited', rawStderr: result.rawStderr };
|
|
18
|
+
}
|
|
19
|
+
if (result.status === 'failed') {
|
|
20
|
+
return { status: 'failed', rawStderr: result.rawStderr };
|
|
21
|
+
}
|
|
22
|
+
const session = createClaudeSession({
|
|
23
|
+
sessionId: result.sessionId,
|
|
24
|
+
jobId: input.jobId,
|
|
25
|
+
jobType: input.jobType,
|
|
26
|
+
localPath: input.localPath,
|
|
27
|
+
mergeRequestId: input.mergeRequestId,
|
|
28
|
+
dispatchedAt: deps.now(),
|
|
29
|
+
});
|
|
30
|
+
return { status: 'dispatched', session };
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=dispatchClaudeSession.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dispatchClaudeSession.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,mBAAmB,GACpB,MAAM,qEAAqE,CAAC;AA6B7E,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,KAAiC,EACjC,IAAuC;IAEvC,IAAI,IAAI,CAAC,WAAW,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAC1C,OAAO,EAAE,MAAM,EAAE,8BAA8B,EAAE,CAAC;IACpD,CAAC;IAED,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,cAAc,EAAE,CAAC;QAC5C,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC;QAChD,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,OAAO,EAAE,KAAK,CAAC,OAAO;KACvB,CAAC,CAAC;IAEH,IAAI,MAAM,CAAC,MAAM,KAAK,cAAc,EAAE,CAAC;QACrC,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC;IACjE,CAAC;IAED,IAAI,MAAM,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QAC/B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC;IAC3D,CAAC;IAED,MAAM,OAAO,GAAG,mBAAmB,CAAC;QAClC,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,YAAY,EAAE,IAAI,CAAC,GAAG,EAAE;KACzB,CAAC,CAAC;IAEH,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,CAAC;AAC3C,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { ClaudeSession } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
2
|
+
import type { ReviewReportGateway } from '../../../modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js';
|
|
3
|
+
export interface RetrieveReviewReportInput {
|
|
4
|
+
session: ClaudeSession;
|
|
5
|
+
today: Date;
|
|
6
|
+
mergeRequestNumber: number;
|
|
7
|
+
}
|
|
8
|
+
export interface RetrieveReviewReportDependencies {
|
|
9
|
+
reportGateway: ReviewReportGateway;
|
|
10
|
+
}
|
|
11
|
+
export type RetrieveReviewReportResult = {
|
|
12
|
+
status: 'found';
|
|
13
|
+
content: string;
|
|
14
|
+
path: string;
|
|
15
|
+
} | {
|
|
16
|
+
status: 'missing';
|
|
17
|
+
expectedPath: string;
|
|
18
|
+
};
|
|
19
|
+
export declare function retrieveReviewReport(input: RetrieveReviewReportInput, deps: RetrieveReviewReportDependencies): RetrieveReviewReportResult;
|
|
20
|
+
//# sourceMappingURL=retrieveReviewReport.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retrieveReviewReport.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/retrieveReviewReport.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4EAA4E,CAAC;AAChH,OAAO,KAAK,EACV,mBAAmB,EAEpB,MAAM,gFAAgF,CAAC;AAExF,MAAM,WAAW,yBAAyB;IACxC,OAAO,EAAE,aAAa,CAAC;IACvB,KAAK,EAAE,IAAI,CAAC;IACZ,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,gCAAgC;IAC/C,aAAa,EAAE,mBAAmB,CAAC;CACpC;AAED,MAAM,MAAM,0BAA0B,GAClC;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAClD;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC;AAMhD,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,yBAAyB,EAChC,IAAI,EAAE,gCAAgC,GACrC,0BAA0B,CAa5B"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
function formatIsoDate(today) {
|
|
2
|
+
return today.toISOString().slice(0, 10);
|
|
3
|
+
}
|
|
4
|
+
export function retrieveReviewReport(input, deps) {
|
|
5
|
+
const location = {
|
|
6
|
+
localPath: input.session.localPath,
|
|
7
|
+
isoDate: formatIsoDate(input.today),
|
|
8
|
+
mergeRequestNumber: input.mergeRequestNumber,
|
|
9
|
+
jobType: input.session.jobType,
|
|
10
|
+
};
|
|
11
|
+
const found = deps.reportGateway.read(location);
|
|
12
|
+
if (found) {
|
|
13
|
+
return { status: 'found', content: found.content, path: found.path };
|
|
14
|
+
}
|
|
15
|
+
return { status: 'missing', expectedPath: deps.reportGateway.buildPath(location) };
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=retrieveReviewReport.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retrieveReviewReport.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/retrieveReviewReport.usecase.ts"],"names":[],"mappings":"AAoBA,SAAS,aAAa,CAAC,KAAW;IAChC,OAAO,KAAK,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,KAAgC,EAChC,IAAsC;IAEtC,MAAM,QAAQ,GAAyB;QACrC,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,SAAS;QAClC,OAAO,EAAE,aAAa,CAAC,KAAK,CAAC,KAAK,CAAC;QACnC,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;QAC5C,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO;KAC/B,CAAC;IAEF,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChD,IAAI,KAAK,EAAE,CAAC;QACV,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;IACvE,CAAC;IACD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC;AACrF,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { BillingStateGateway } from '../../../modules/claude-invocation/entities/billingState/billingState.gateway.js';
|
|
2
|
+
import type { EnvironmentGateway } from '../../../modules/claude-invocation/entities/billingState/environment.gateway.js';
|
|
3
|
+
import type { ClaudeDispatchFlags, ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
4
|
+
import type { ClaudeSessionJobType } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
5
|
+
import type { McpCompletionBridge } from '../../../modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js';
|
|
6
|
+
import type { ReviewReportGateway } from '../../../modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js';
|
|
7
|
+
export interface RunClaudeReviewJobInput {
|
|
8
|
+
jobId: string;
|
|
9
|
+
jobType: ClaudeSessionJobType;
|
|
10
|
+
prompt: string;
|
|
11
|
+
flags: ClaudeDispatchFlags;
|
|
12
|
+
localPath: string;
|
|
13
|
+
mergeRequestId: string;
|
|
14
|
+
mergeRequestNumber: number;
|
|
15
|
+
attempt: number;
|
|
16
|
+
signal?: AbortSignal;
|
|
17
|
+
}
|
|
18
|
+
export interface RunClaudeReviewJobDependencies {
|
|
19
|
+
sessionGateway: ClaudeSessionGateway;
|
|
20
|
+
completionBridge: McpCompletionBridge;
|
|
21
|
+
reportGateway: ReviewReportGateway;
|
|
22
|
+
billingState: BillingStateGateway;
|
|
23
|
+
environment: EnvironmentGateway;
|
|
24
|
+
now: () => Date;
|
|
25
|
+
timeoutMs: number;
|
|
26
|
+
pollIntervalMs: number;
|
|
27
|
+
}
|
|
28
|
+
export type RunClaudeReviewJobResult = {
|
|
29
|
+
status: 'completed';
|
|
30
|
+
reportPath: string;
|
|
31
|
+
content: string;
|
|
32
|
+
} | {
|
|
33
|
+
status: 'failed';
|
|
34
|
+
reason: string;
|
|
35
|
+
} | {
|
|
36
|
+
status: 'retry';
|
|
37
|
+
delayMs: number;
|
|
38
|
+
attempt: number;
|
|
39
|
+
};
|
|
40
|
+
export declare function runClaudeReviewJob(input: RunClaudeReviewJobInput, deps: RunClaudeReviewJobDependencies): Promise<RunClaudeReviewJobResult>;
|
|
41
|
+
//# sourceMappingURL=runClaudeReviewJob.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runClaudeReviewJob.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2EAA2E,CAAC;AACrH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0EAA0E,CAAC;AACnH,OAAO,KAAK,EACV,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,6EAA6E,CAAC;AACrF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,4EAA4E,CAAC;AACvH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iFAAiF,CAAC;AAE3H,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gFAAgF,CAAC;AAO1H,MAAM,WAAW,uBAAuB;IACtC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,oBAAoB,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,mBAAmB,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,WAAW,CAAC;CACtB;AAED,MAAM,WAAW,8BAA8B;IAC7C,cAAc,EAAE,oBAAoB,CAAC;IACrC,gBAAgB,EAAE,mBAAmB,CAAC;IACtC,aAAa,EAAE,mBAAmB,CAAC;IACnC,YAAY,EAAE,mBAAmB,CAAC;IAClC,WAAW,EAAE,kBAAkB,CAAC;IAChC,GAAG,EAAE,MAAM,IAAI,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,MAAM,wBAAwB,GAChC;IAAE,MAAM,EAAE,WAAW,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GAC5D;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACpC;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC;AAE1D,wBAAsB,kBAAkB,CACtC,KAAK,EAAE,uBAAuB,EAC9B,IAAI,EAAE,8BAA8B,GACnC,OAAO,CAAC,wBAAwB,CAAC,CA2GnC"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { planRetry } from '../../../modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.js';
|
|
2
|
+
import { dispatchClaudeSession } from '../../../modules/claude-invocation/usecases/dispatchClaudeSession.usecase.js';
|
|
3
|
+
import { awaitSessionCompletion } from '../../../modules/claude-invocation/usecases/awaitSessionCompletion.usecase.js';
|
|
4
|
+
import { retrieveReviewReport } from '../../../modules/claude-invocation/usecases/retrieveReviewReport.usecase.js';
|
|
5
|
+
import { cleanupClaudeSession } from '../../../modules/claude-invocation/usecases/cleanupClaudeSession.usecase.js';
|
|
6
|
+
export async function runClaudeReviewJob(input, deps) {
|
|
7
|
+
if (input.signal?.aborted) {
|
|
8
|
+
return { status: 'failed', reason: 'cancelled' };
|
|
9
|
+
}
|
|
10
|
+
const dispatchResult = await dispatchClaudeSession({
|
|
11
|
+
jobId: input.jobId,
|
|
12
|
+
jobType: input.jobType,
|
|
13
|
+
prompt: input.prompt,
|
|
14
|
+
flags: input.flags,
|
|
15
|
+
localPath: input.localPath,
|
|
16
|
+
mergeRequestId: input.mergeRequestId,
|
|
17
|
+
}, {
|
|
18
|
+
sessionGateway: deps.sessionGateway,
|
|
19
|
+
environment: deps.environment,
|
|
20
|
+
billingState: deps.billingState,
|
|
21
|
+
now: deps.now,
|
|
22
|
+
});
|
|
23
|
+
if (dispatchResult.status === 'billing-regression-prevented') {
|
|
24
|
+
return { status: 'failed', reason: 'billing-regression-prevented' };
|
|
25
|
+
}
|
|
26
|
+
if (dispatchResult.status === 'paused') {
|
|
27
|
+
return { status: 'failed', reason: 'dispatch-paused' };
|
|
28
|
+
}
|
|
29
|
+
if (dispatchResult.status === 'rate-limited') {
|
|
30
|
+
const retry = planRetry(input.attempt);
|
|
31
|
+
if (retry.status === 'give-up') {
|
|
32
|
+
return { status: 'failed', reason: 'rate-limited-give-up' };
|
|
33
|
+
}
|
|
34
|
+
return { status: 'retry', delayMs: retry.delayMs, attempt: retry.nextAttempt };
|
|
35
|
+
}
|
|
36
|
+
if (dispatchResult.status === 'failed') {
|
|
37
|
+
return { status: 'failed', reason: `dispatch-failed: ${dispatchResult.rawStderr}` };
|
|
38
|
+
}
|
|
39
|
+
const { session } = dispatchResult;
|
|
40
|
+
const abortListener = input.signal
|
|
41
|
+
? () => {
|
|
42
|
+
void deps.sessionGateway.stop(session.sessionId);
|
|
43
|
+
deps.completionBridge.publish(input.jobId, {
|
|
44
|
+
source: 'mcp',
|
|
45
|
+
outcome: 'stopped',
|
|
46
|
+
reason: 'cancelled',
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
: null;
|
|
50
|
+
if (input.signal && abortListener) {
|
|
51
|
+
input.signal.addEventListener('abort', abortListener);
|
|
52
|
+
}
|
|
53
|
+
let completion;
|
|
54
|
+
try {
|
|
55
|
+
completion = await awaitSessionCompletion({
|
|
56
|
+
session,
|
|
57
|
+
timeoutMs: deps.timeoutMs,
|
|
58
|
+
pollIntervalMs: deps.pollIntervalMs,
|
|
59
|
+
}, {
|
|
60
|
+
sessionGateway: deps.sessionGateway,
|
|
61
|
+
completionBridge: deps.completionBridge,
|
|
62
|
+
now: deps.now,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
finally {
|
|
66
|
+
if (input.signal && abortListener) {
|
|
67
|
+
input.signal.removeEventListener('abort', abortListener);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
await cleanupClaudeSession({ sessionId: session.sessionId }, { sessionGateway: deps.sessionGateway });
|
|
71
|
+
if (completion.source === 'timeout') {
|
|
72
|
+
return { status: 'failed', reason: 'timeout' };
|
|
73
|
+
}
|
|
74
|
+
if (completion.outcome !== 'completed') {
|
|
75
|
+
const reasonSuffix = completion.reason !== null ? `: ${completion.reason}` : '';
|
|
76
|
+
return { status: 'failed', reason: `outcome-${completion.outcome}${reasonSuffix}` };
|
|
77
|
+
}
|
|
78
|
+
const report = retrieveReviewReport({
|
|
79
|
+
session,
|
|
80
|
+
today: deps.now(),
|
|
81
|
+
mergeRequestNumber: input.mergeRequestNumber,
|
|
82
|
+
}, { reportGateway: deps.reportGateway });
|
|
83
|
+
if (report.status === 'missing') {
|
|
84
|
+
return { status: 'failed', reason: 'report-missing' };
|
|
85
|
+
}
|
|
86
|
+
return { status: 'completed', reportPath: report.path, content: report.content };
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=runClaudeReviewJob.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runClaudeReviewJob.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,SAAS,EAAE,MAAM,iFAAiF,CAAC;AAC5G,OAAO,EAAE,qBAAqB,EAAE,MAAM,uEAAuE,CAAC;AAC9G,OAAO,EAAE,sBAAsB,EAAE,MAAM,wEAAwE,CAAC;AAChH,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AAC5G,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AA8B5G,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,KAA8B,EAC9B,IAAoC;IAEpC,IAAI,KAAK,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC;QAC1B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;IACnD,CAAC;IAED,MAAM,cAAc,GAAG,MAAM,qBAAqB,CAChD;QACE,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,cAAc,EAAE,KAAK,CAAC,cAAc;KACrC,EACD;QACE,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;QAC/B,GAAG,EAAE,IAAI,CAAC,GAAG;KACd,CACF,CAAC;IAEF,IAAI,cAAc,CAAC,MAAM,KAAK,8BAA8B,EAAE,CAAC;QAC7D,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,8BAA8B,EAAE,CAAC;IACtE,CAAC;IAED,IAAI,cAAc,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QACvC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,iBAAiB,EAAE,CAAC;IACzD,CAAC;IAED,IAAI,cAAc,CAAC,MAAM,KAAK,cAAc,EAAE,CAAC;QAC7C,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACvC,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC/B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,sBAAsB,EAAE,CAAC;QAC9D,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC;IACjF,CAAC;IAED,IAAI,cAAc,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QACvC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,oBAAoB,cAAc,CAAC,SAAS,EAAE,EAAE,CAAC;IACtF,CAAC;IAED,MAAM,EAAE,OAAO,EAAE,GAAG,cAAc,CAAC;IAEnC,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM;QAChC,CAAC,CAAC,GAAS,EAAE;YACT,KAAK,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACjD,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE;gBACzC,MAAM,EAAE,KAAK;gBACb,OAAO,EAAE,SAAS;gBAClB,MAAM,EAAE,WAAW;aACpB,CAAC,CAAC;QACL,CAAC;QACH,CAAC,CAAC,IAAI,CAAC;IAET,IAAI,KAAK,CAAC,MAAM,IAAI,aAAa,EAAE,CAAC;QAClC,KAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,UAA6B,CAAC;IAClC,IAAI,CAAC;QACH,UAAU,GAAG,MAAM,sBAAsB,CACvC;YACE,OAAO;YACP,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,EACD;YACE,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CACF,CAAC;IACJ,CAAC;YAAS,CAAC;QACT,IAAI,KAAK,CAAC,MAAM,IAAI,aAAa,EAAE,CAAC;YAClC,KAAK,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QAC3D,CAAC;IACH,CAAC;IAED,MAAM,oBAAoB,CACxB,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,EAAE,EAChC,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,CACxC,CAAC;IAEF,IAAI,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QACpC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;IACjD,CAAC;IAED,IAAI,UAAU,CAAC,OAAO,KAAK,WAAW,EAAE,CAAC;QACvC,MAAM,YAAY,GAAG,UAAU,CAAC,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAChF,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,UAAU,CAAC,OAAO,GAAG,YAAY,EAAE,EAAE,CAAC;IACtF,CAAC;IAED,MAAM,MAAM,GAAG,oBAAoB,CACjC;QACE,OAAO;QACP,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE;QACjB,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;KAC7C,EACD,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,CACtC,CAAC;IAEF,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAChC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,EAAE,CAAC;IACxD,CAAC;IAED,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC;AACnF,CAAC"}
|
package/dist/modules/cli-configuration/interface-adapters/controllers/http/health.routes.d.ts
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import type { FastifyPluginAsync } from 'fastify';
|
|
2
2
|
import type { VersionCachePort } from '../../../../../modules/cli-configuration/entities/packageVersion/versionCache.gateway.js';
|
|
3
|
+
import type { SupervisorStatusStore } from '../../../../../modules/supervisor-management/entities/supervisor/supervisorStatusStore.gateway.js';
|
|
3
4
|
interface HealthRoutesOptions {
|
|
4
5
|
getConfig: () => {
|
|
5
6
|
version: string;
|
|
6
7
|
};
|
|
7
8
|
versionCache?: VersionCachePort;
|
|
9
|
+
supervisorStatusStore?: SupervisorStatusStore;
|
|
8
10
|
}
|
|
9
11
|
export declare const healthRoutes: FastifyPluginAsync<HealthRoutesOptions>;
|
|
10
12
|
export {};
|
package/dist/modules/cli-configuration/interface-adapters/controllers/http/health.routes.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"health.routes.d.ts","sourceRoot":"","sources":["../../../../../../src/modules/cli-configuration/interface-adapters/controllers/http/health.routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,6EAA6E,CAAC;
|
|
1
|
+
{"version":3,"file":"health.routes.d.ts","sourceRoot":"","sources":["../../../../../../src/modules/cli-configuration/interface-adapters/controllers/http/health.routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,6EAA6E,CAAC;AAEpH,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sFAAsF,CAAC;AAElI,UAAU,mBAAmB;IAC3B,SAAS,EAAE,MAAM;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACrC,YAAY,CAAC,EAAE,gBAAgB,CAAC;IAChC,qBAAqB,CAAC,EAAE,qBAAqB,CAAC;CAC/C;AAsBD,eAAO,MAAM,YAAY,EAAE,kBAAkB,CAAC,mBAAmB,CAiChE,CAAC"}
|