reviewflow 3.13.0 → 3.15.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 +2 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -1
- package/dist/frameworks/claude/claudeInvoker.js +72 -28
- package/dist/frameworks/claude/claudeInvoker.js.map +1 -1
- 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 +2 -0
- package/dist/main/dependencies.d.ts.map +1 -1
- package/dist/main/dependencies.js +2 -0
- package/dist/main/dependencies.js.map +1 -1
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +11 -0
- package/dist/main/routes.js.map +1 -1
- package/dist/main/server.d.ts.map +1 -1
- package/dist/main/server.js +21 -0
- package/dist/main/server.js.map +1 -1
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.d.ts +3 -1
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.d.ts.map +1 -1
- package/dist/modules/claude-invocation/entities/claudeSession/sessionUsage.schema.d.ts +13 -0
- package/dist/modules/claude-invocation/entities/claudeSession/sessionUsage.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/sessionUsage.schema.js +12 -0
- package/dist/modules/claude-invocation/entities/claudeSession/sessionUsage.schema.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.d.ts +7 -1
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.d.ts.map +1 -1
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.js +73 -1
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.js.map +1 -1
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.d.ts +2 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.d.ts.map +1 -1
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.js +9 -1
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.js.map +1 -1
- 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/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/token-accounting/entities/modelPricing/modelPricing.d.ts +16 -0
- package/dist/modules/token-accounting/entities/modelPricing/modelPricing.d.ts.map +1 -0
- package/dist/modules/token-accounting/entities/modelPricing/modelPricing.js +44 -0
- package/dist/modules/token-accounting/entities/modelPricing/modelPricing.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.js +2 -2
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.js.map +1 -1
- 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/171-bg-token-usage-tracking.acceptance.test.d.ts +2 -0
- package/dist/tests/acceptance/171-bg-token-usage-tracking.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/171-bg-token-usage-tracking.acceptance.test.js +320 -0
- package/dist/tests/acceptance/171-bg-token-usage-tracking.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/integration/claudeInvocation.integration.test.js +2 -2
- package/dist/tests/integration/claudeInvocation.integration.test.js.map +1 -1
- 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 +8 -0
- package/dist/tests/stubs/claudeSession.stub.d.ts.map +1 -1
- package/dist/tests/stubs/claudeSession.stub.js +9 -0
- package/dist/tests/stubs/claudeSession.stub.js.map +1 -1
- 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/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/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/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/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/interface-adapters/gateways/claudeSession.cli.gateway.test.js +119 -1
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.js.map +1 -1
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.js +1 -1
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.js.map +1 -1
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.js +91 -1
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.js.map +1 -1
- 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/token-accounting/entities/modelPricing/modelPricing.test.d.ts +2 -0
- package/dist/tests/units/modules/token-accounting/entities/modelPricing/modelPricing.test.d.ts.map +1 -0
- package/dist/tests/units/modules/token-accounting/entities/modelPricing/modelPricing.test.js +90 -0
- package/dist/tests/units/modules/token-accounting/entities/modelPricing/modelPricing.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/package.json +1 -1
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SupervisorStatusStore } from '../../../../modules/supervisor-management/entities/supervisor/supervisorStatusStore.gateway.js';
|
|
2
|
+
import { type SupervisorStatus } from '../../../../modules/supervisor-management/entities/supervisor/supervisorStatus.schema.js';
|
|
3
|
+
export declare class InMemorySupervisorStatusStore implements SupervisorStatusStore {
|
|
4
|
+
private current;
|
|
5
|
+
read(): SupervisorStatus;
|
|
6
|
+
set(status: SupervisorStatus): void;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=supervisorStatusStore.memory.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supervisorStatusStore.memory.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/supervisor-management/interface-adapters/gateways/supervisorStatusStore.memory.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sFAAsF,CAAC;AAClI,OAAO,EAEL,KAAK,gBAAgB,EACtB,MAAM,gFAAgF,CAAC;AAIxF,qBAAa,6BAA8B,YAAW,qBAAqB;IACzE,OAAO,CAAC,OAAO,CAAoE;IAEnF,IAAI,IAAI,gBAAgB;IAQxB,GAAG,CAAC,MAAM,EAAE,gBAAgB,GAAG,IAAI;CAOpC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { createSupervisorStatus, } from '../../../../modules/supervisor-management/entities/supervisor/supervisorStatus.schema.js';
|
|
2
|
+
const EPOCH = new Date(0);
|
|
3
|
+
export class InMemorySupervisorStatusStore {
|
|
4
|
+
current = createSupervisorStatus('unknown', null, EPOCH);
|
|
5
|
+
read() {
|
|
6
|
+
return {
|
|
7
|
+
state: this.current.state,
|
|
8
|
+
reason: this.current.reason,
|
|
9
|
+
lastCheckedAt: new Date(this.current.lastCheckedAt.getTime()),
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
set(status) {
|
|
13
|
+
this.current = {
|
|
14
|
+
state: status.state,
|
|
15
|
+
reason: status.reason,
|
|
16
|
+
lastCheckedAt: new Date(status.lastCheckedAt.getTime()),
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=supervisorStatusStore.memory.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supervisorStatusStore.memory.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/supervisor-management/interface-adapters/gateways/supervisorStatusStore.memory.gateway.ts"],"names":[],"mappings":"AACA,OAAO,EACL,sBAAsB,GAEvB,MAAM,gFAAgF,CAAC;AAExF,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;AAE1B,MAAM,OAAO,6BAA6B;IAChC,OAAO,GAAqB,sBAAsB,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IAEnF,IAAI;QACF,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK;YACzB,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;YAC3B,aAAa,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;SAC9D,CAAC;IACJ,CAAC;IAED,GAAG,CAAC,MAAwB;QAC1B,IAAI,CAAC,OAAO,GAAG;YACb,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,aAAa,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;SACxD,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Logger } from 'pino';
|
|
2
|
+
import type { SupervisorGateway } from '../../../modules/supervisor-management/entities/supervisor/supervisor.gateway.js';
|
|
3
|
+
import type { SupervisorLockGateway } from '../../../modules/supervisor-management/entities/supervisor/supervisorLock.gateway.js';
|
|
4
|
+
import type { SupervisorStatusStore } from '../../../modules/supervisor-management/entities/supervisor/supervisorStatusStore.gateway.js';
|
|
5
|
+
import { type SupervisorStatus } from '../../../modules/supervisor-management/entities/supervisor/supervisorStatus.schema.js';
|
|
6
|
+
export interface CheckSupervisorAndRespawnDependencies {
|
|
7
|
+
supervisorGateway: SupervisorGateway;
|
|
8
|
+
lockGateway: SupervisorLockGateway;
|
|
9
|
+
statusStore: SupervisorStatusStore;
|
|
10
|
+
logger: Logger;
|
|
11
|
+
now: () => Date;
|
|
12
|
+
}
|
|
13
|
+
export declare function checkSupervisorAndRespawn(deps: CheckSupervisorAndRespawnDependencies): Promise<SupervisorStatus>;
|
|
14
|
+
//# sourceMappingURL=checkSupervisorAndRespawn.usecase.d.ts.map
|
package/dist/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkSupervisorAndRespawn.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2EAA2E,CAAC;AACnH,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,+EAA+E,CAAC;AAC3H,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sFAAsF,CAAC;AAClI,OAAO,EAEL,KAAK,gBAAgB,EACtB,MAAM,gFAAgF,CAAC;AAKxF,MAAM,WAAW,qCAAqC;IACpD,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,WAAW,EAAE,qBAAqB,CAAC;IACnC,WAAW,EAAE,qBAAqB,CAAC;IACnC,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAED,wBAAsB,yBAAyB,CAC7C,IAAI,EAAE,qCAAqC,GAC1C,OAAO,CAAC,gBAAgB,CAAC,CA6D3B"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { createSupervisorStatus, } from '../../../modules/supervisor-management/entities/supervisor/supervisorStatus.schema.js';
|
|
2
|
+
const SPAWN_FAILED_REASON = 'supervisor-spawn-failed';
|
|
3
|
+
const LOCK_HELD_REASON = 'supervisor-lock-held';
|
|
4
|
+
export async function checkSupervisorAndRespawn(deps) {
|
|
5
|
+
const { supervisorGateway, lockGateway, statusStore, logger, now } = deps;
|
|
6
|
+
const previousState = statusStore.read().state;
|
|
7
|
+
const probe = await supervisorGateway.probe();
|
|
8
|
+
if (probe.state === 'up') {
|
|
9
|
+
const status = createSupervisorStatus('up', null, now());
|
|
10
|
+
statusStore.set(status);
|
|
11
|
+
logger.info('Claude agents supervisor reachable');
|
|
12
|
+
return status;
|
|
13
|
+
}
|
|
14
|
+
if (previousState === 'up') {
|
|
15
|
+
logger.warn({ reason: probe.reason }, 'Claude agents supervisor went down — attempting respawn');
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
logger.warn({ reason: probe.reason }, 'Claude agents supervisor unreachable — attempting respawn');
|
|
19
|
+
}
|
|
20
|
+
const lock = await lockGateway.acquire();
|
|
21
|
+
if (!lock.acquired) {
|
|
22
|
+
logger.warn({ reason: lock.reason }, 'Skipping supervisor respawn: another ReviewFlow process holds the lock');
|
|
23
|
+
const status = createSupervisorStatus('down', LOCK_HELD_REASON, now());
|
|
24
|
+
statusStore.set(status);
|
|
25
|
+
return status;
|
|
26
|
+
}
|
|
27
|
+
try {
|
|
28
|
+
const spawnResult = await supervisorGateway.spawnDetached();
|
|
29
|
+
if (spawnResult.state === 'failed') {
|
|
30
|
+
logger.warn({ reason: spawnResult.reason }, 'Failed to spawn Claude agents supervisor');
|
|
31
|
+
const status = createSupervisorStatus('down', SPAWN_FAILED_REASON, now());
|
|
32
|
+
statusStore.set(status);
|
|
33
|
+
return status;
|
|
34
|
+
}
|
|
35
|
+
logger.info({ pid: spawnResult.pid }, `Claude agents supervisor spawned (pid=${spawnResult.pid ?? 'unknown'})`);
|
|
36
|
+
const status = createSupervisorStatus('up', null, now());
|
|
37
|
+
statusStore.set(status);
|
|
38
|
+
return status;
|
|
39
|
+
}
|
|
40
|
+
catch (error) {
|
|
41
|
+
const reason = error instanceof Error ? error.message : 'unknown spawn error';
|
|
42
|
+
logger.warn({ reason }, 'Spawn attempt threw an error');
|
|
43
|
+
const status = createSupervisorStatus('down', SPAWN_FAILED_REASON, now());
|
|
44
|
+
statusStore.set(status);
|
|
45
|
+
return status;
|
|
46
|
+
}
|
|
47
|
+
finally {
|
|
48
|
+
await lockGateway.release();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=checkSupervisorAndRespawn.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkSupervisorAndRespawn.usecase.js","sourceRoot":"","sources":["../../../../src/modules/supervisor-management/usecases/checkSupervisorAndRespawn.usecase.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { TokenUsage } from '../../../../modules/token-accounting/entities/tokenUsage/tokenUsage.schema.js';
|
|
2
|
+
interface ModelRates {
|
|
3
|
+
inputPerMillion: number;
|
|
4
|
+
outputPerMillion: number;
|
|
5
|
+
cacheCreationPerMillion: number;
|
|
6
|
+
cacheReadPerMillion: number;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Anthropic public pricing per 1M tokens.
|
|
10
|
+
* Last updated: 2026-05-23 - source: https://www.anthropic.com/pricing
|
|
11
|
+
* Refresh on Claude model family bumps.
|
|
12
|
+
*/
|
|
13
|
+
export declare const MODEL_PRICING_USD_PER_MILLION: Record<string, ModelRates>;
|
|
14
|
+
export declare function computeCostUsd(model: string, tokens: TokenUsage): number;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=modelPricing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"modelPricing.d.ts","sourceRoot":"","sources":["../../../../../src/modules/token-accounting/entities/modelPricing/modelPricing.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qEAAqE,CAAC;AAEtG,UAAU,UAAU;IAClB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,uBAAuB,EAAE,MAAM,CAAC;IAChC,mBAAmB,EAAE,MAAM,CAAC;CAC7B;AAED;;;;GAIG;AACH,eAAO,MAAM,6BAA6B,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAmBpE,CAAC;AAaF,wBAAgB,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,GAAG,MAAM,CASxE"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Anthropic public pricing per 1M tokens.
|
|
3
|
+
* Last updated: 2026-05-23 - source: https://www.anthropic.com/pricing
|
|
4
|
+
* Refresh on Claude model family bumps.
|
|
5
|
+
*/
|
|
6
|
+
export const MODEL_PRICING_USD_PER_MILLION = {
|
|
7
|
+
'claude-opus-4': {
|
|
8
|
+
inputPerMillion: 15,
|
|
9
|
+
outputPerMillion: 75,
|
|
10
|
+
cacheCreationPerMillion: 18.75,
|
|
11
|
+
cacheReadPerMillion: 1.5,
|
|
12
|
+
},
|
|
13
|
+
'claude-sonnet-4': {
|
|
14
|
+
inputPerMillion: 3,
|
|
15
|
+
outputPerMillion: 15,
|
|
16
|
+
cacheCreationPerMillion: 3.75,
|
|
17
|
+
cacheReadPerMillion: 0.3,
|
|
18
|
+
},
|
|
19
|
+
'claude-haiku-4-5': {
|
|
20
|
+
inputPerMillion: 1,
|
|
21
|
+
outputPerMillion: 5,
|
|
22
|
+
cacheCreationPerMillion: 1.25,
|
|
23
|
+
cacheReadPerMillion: 0.1,
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
const FALLBACK_RATES = MODEL_PRICING_USD_PER_MILLION['claude-opus-4'];
|
|
27
|
+
function resolveRates(model) {
|
|
28
|
+
for (const prefix of Object.keys(MODEL_PRICING_USD_PER_MILLION)) {
|
|
29
|
+
if (model.startsWith(prefix)) {
|
|
30
|
+
return MODEL_PRICING_USD_PER_MILLION[prefix];
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return FALLBACK_RATES;
|
|
34
|
+
}
|
|
35
|
+
export function computeCostUsd(model, tokens) {
|
|
36
|
+
const rates = resolveRates(model);
|
|
37
|
+
const million = 1_000_000;
|
|
38
|
+
const inputCost = (tokens.inputTokens / million) * rates.inputPerMillion;
|
|
39
|
+
const outputCost = (tokens.outputTokens / million) * rates.outputPerMillion;
|
|
40
|
+
const cacheCreationCost = (tokens.cacheCreationInputTokens / million) * rates.cacheCreationPerMillion;
|
|
41
|
+
const cacheReadCost = (tokens.cacheReadInputTokens / million) * rates.cacheReadPerMillion;
|
|
42
|
+
return inputCost + outputCost + cacheCreationCost + cacheReadCost;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=modelPricing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"modelPricing.js","sourceRoot":"","sources":["../../../../../src/modules/token-accounting/entities/modelPricing/modelPricing.ts"],"names":[],"mappings":"AASA;;;;GAIG;AACH,MAAM,CAAC,MAAM,6BAA6B,GAA+B;IACvE,eAAe,EAAE;QACf,eAAe,EAAE,EAAE;QACnB,gBAAgB,EAAE,EAAE;QACpB,uBAAuB,EAAE,KAAK;QAC9B,mBAAmB,EAAE,GAAG;KACzB;IACD,iBAAiB,EAAE;QACjB,eAAe,EAAE,CAAC;QAClB,gBAAgB,EAAE,EAAE;QACpB,uBAAuB,EAAE,IAAI;QAC7B,mBAAmB,EAAE,GAAG;KACzB;IACD,kBAAkB,EAAE;QAClB,eAAe,EAAE,CAAC;QAClB,gBAAgB,EAAE,CAAC;QACnB,uBAAuB,EAAE,IAAI;QAC7B,mBAAmB,EAAE,GAAG;KACzB;CACF,CAAC;AAEF,MAAM,cAAc,GAAe,6BAA6B,CAAC,eAAe,CAAC,CAAC;AAElF,SAAS,YAAY,CAAC,KAAa;IACjC,KAAK,MAAM,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,EAAE,CAAC;QAChE,IAAI,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAC7B,OAAO,6BAA6B,CAAC,MAAM,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;IACD,OAAO,cAAc,CAAC;AACxB,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,KAAa,EAAE,MAAkB;IAC9D,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;IAClC,MAAM,OAAO,GAAG,SAAS,CAAC;IAC1B,MAAM,SAAS,GAAG,CAAC,MAAM,CAAC,WAAW,GAAG,OAAO,CAAC,GAAG,KAAK,CAAC,eAAe,CAAC;IACzE,MAAM,UAAU,GAAG,CAAC,MAAM,CAAC,YAAY,GAAG,OAAO,CAAC,GAAG,KAAK,CAAC,gBAAgB,CAAC;IAC5E,MAAM,iBAAiB,GACrB,CAAC,MAAM,CAAC,wBAAwB,GAAG,OAAO,CAAC,GAAG,KAAK,CAAC,uBAAuB,CAAC;IAC9E,MAAM,aAAa,GAAG,CAAC,MAAM,CAAC,oBAAoB,GAAG,OAAO,CAAC,GAAG,KAAK,CAAC,mBAAmB,CAAC;IAC1F,OAAO,SAAS,GAAG,UAAU,GAAG,iBAAiB,GAAG,aAAa,CAAC;AACpE,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export type GitCommandKind = 'fetch' | 'worktree-add' | 'worktree-remove' | 'worktree-prune' | 'reset-hard';
|
|
2
|
+
export interface GitCommand {
|
|
3
|
+
kind: GitCommandKind;
|
|
4
|
+
args: readonly string[];
|
|
5
|
+
cwd: string;
|
|
6
|
+
}
|
|
7
|
+
export interface GitCommandResult {
|
|
8
|
+
exitCode: number;
|
|
9
|
+
stdout: string;
|
|
10
|
+
stderr: string;
|
|
11
|
+
}
|
|
12
|
+
export interface GitCommandExecutor {
|
|
13
|
+
execute(command: GitCommand): Promise<GitCommandResult>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=gitCommand.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitCommand.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/gitCommand/gitCommand.gateway.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GACtB,OAAO,GACP,cAAc,GACd,iBAAiB,GACjB,gBAAgB,GAChB,YAAY,CAAC;AAEjB,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,cAAc,CAAC;IACrB,IAAI,EAAE,SAAS,MAAM,EAAE,CAAC;IACxB,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,kBAAkB;IACjC,OAAO,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;CACzD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitCommand.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/gitCommand/gitCommand.gateway.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { FetchRef, MrSource, WorktreeIdentity, WorktreePath } from '../../../../modules/worktree-management/entities/worktree/worktree.schema.js';
|
|
2
|
+
/**
|
|
3
|
+
* Single chokepoint constructor for the WorktreePath branded type. Any
|
|
4
|
+
* other call site that needs a WorktreePath must go through this factory
|
|
5
|
+
* rather than casting a raw string. Validates absoluteness so accidental
|
|
6
|
+
* relative paths are caught at the boundary.
|
|
7
|
+
*/
|
|
8
|
+
export declare function createWorktreePath(value: string): WorktreePath;
|
|
9
|
+
export declare function deriveWorktreeSlug(projectPath: string): string;
|
|
10
|
+
export declare function deriveWorktreeDirectoryName(identity: WorktreeIdentity): string;
|
|
11
|
+
export declare function deriveWorktreePath(identity: WorktreeIdentity): WorktreePath;
|
|
12
|
+
export declare function deriveFetchRef(source: MrSource, sourceBranch: string, mrNumber: number): FetchRef;
|
|
13
|
+
export declare function parseWorktreeDirectoryName(directoryName: string): WorktreeIdentity | null;
|
|
14
|
+
//# sourceMappingURL=worktree.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.d.ts","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/worktree/worktree.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,QAAQ,EACR,QAAQ,EACR,gBAAgB,EAChB,YAAY,EACb,MAAM,oEAAoE,CAAC;AAE5E;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY,CAK9D;AAED,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAE9D;AAED,wBAAgB,2BAA2B,CAAC,QAAQ,EAAE,gBAAgB,GAAG,MAAM,CAG9E;AAED,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,gBAAgB,GAAG,YAAY,CAE3E;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,QAAQ,CAcjG;AAED,wBAAgB,0BAA0B,CACxC,aAAa,EAAE,MAAM,GACpB,gBAAgB,GAAG,IAAI,CAczB"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { EnsureResult, MrSource, RemoveResult, WorktreeEntry, WorktreeIdentity } from '../../../../modules/worktree-management/entities/worktree/worktree.schema.js';
|
|
2
|
+
export interface EnsureWorktreeRequest {
|
|
3
|
+
identity: WorktreeIdentity;
|
|
4
|
+
sourceBranch: string;
|
|
5
|
+
source: MrSource;
|
|
6
|
+
sourceCheckoutPath: string;
|
|
7
|
+
}
|
|
8
|
+
export interface RemoveWorktreeRequest {
|
|
9
|
+
identity: WorktreeIdentity;
|
|
10
|
+
sourceCheckoutPath: string;
|
|
11
|
+
}
|
|
12
|
+
export interface WorktreeGateway {
|
|
13
|
+
ensure(request: EnsureWorktreeRequest): Promise<EnsureResult>;
|
|
14
|
+
remove(request: RemoveWorktreeRequest): Promise<RemoveResult>;
|
|
15
|
+
list(): Promise<WorktreeEntry[]>;
|
|
16
|
+
exists(identity: WorktreeIdentity): Promise<boolean>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=worktree.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/worktree/worktree.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,YAAY,EACZ,QAAQ,EACR,YAAY,EACZ,aAAa,EACb,gBAAgB,EACjB,MAAM,oEAAoE,CAAC;AAE5E,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,YAAY,EAAE,MAAM,CAAC;IACrB,MAAM,EAAE,QAAQ,CAAC;IACjB,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,eAAe;IAC9B,MAAM,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;IAC9D,MAAM,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;IAC9D,IAAI,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IACjC,MAAM,CAAC,QAAQ,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACtD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/worktree/worktree.gateway.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { isAbsolute, join } from 'node:path';
|
|
2
|
+
import { WORKTREE_BASE_DIR } from '../../../../shared/services/daemonPaths.js';
|
|
3
|
+
/**
|
|
4
|
+
* Single chokepoint constructor for the WorktreePath branded type. Any
|
|
5
|
+
* other call site that needs a WorktreePath must go through this factory
|
|
6
|
+
* rather than casting a raw string. Validates absoluteness so accidental
|
|
7
|
+
* relative paths are caught at the boundary.
|
|
8
|
+
*/
|
|
9
|
+
export function createWorktreePath(value) {
|
|
10
|
+
if (value.length === 0 || !isAbsolute(value)) {
|
|
11
|
+
throw new Error(`Invalid worktree path (must be absolute, non-empty): ${value}`);
|
|
12
|
+
}
|
|
13
|
+
return value;
|
|
14
|
+
}
|
|
15
|
+
export function deriveWorktreeSlug(projectPath) {
|
|
16
|
+
return projectPath.replace(/\//g, '-');
|
|
17
|
+
}
|
|
18
|
+
export function deriveWorktreeDirectoryName(identity) {
|
|
19
|
+
const slug = deriveWorktreeSlug(identity.projectPath);
|
|
20
|
+
return `${identity.platform}-${slug}-${identity.mrNumber}`;
|
|
21
|
+
}
|
|
22
|
+
export function deriveWorktreePath(identity) {
|
|
23
|
+
return createWorktreePath(join(WORKTREE_BASE_DIR, deriveWorktreeDirectoryName(identity)));
|
|
24
|
+
}
|
|
25
|
+
export function deriveFetchRef(source, sourceBranch, mrNumber) {
|
|
26
|
+
if (source.kind === 'origin') {
|
|
27
|
+
return {
|
|
28
|
+
remote: 'origin',
|
|
29
|
+
refspec: sourceBranch,
|
|
30
|
+
worktreeRef: `origin/${sourceBranch}`,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
const worktreeRef = `refs/remotes/pr-${mrNumber}/head`;
|
|
34
|
+
return {
|
|
35
|
+
remote: source.cloneUrl,
|
|
36
|
+
refspec: `${sourceBranch}:${worktreeRef}`,
|
|
37
|
+
worktreeRef,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
export function parseWorktreeDirectoryName(directoryName) {
|
|
41
|
+
const match = directoryName.match(/^(gitlab|github)-(.+)-(\d+)$/);
|
|
42
|
+
if (!match)
|
|
43
|
+
return null;
|
|
44
|
+
const platform = match[1] === 'github' ? 'github' : 'gitlab';
|
|
45
|
+
const slug = match[2];
|
|
46
|
+
const mrNumberRaw = match[3];
|
|
47
|
+
if (slug === undefined || mrNumberRaw === undefined)
|
|
48
|
+
return null;
|
|
49
|
+
const mrNumber = Number.parseInt(mrNumberRaw, 10);
|
|
50
|
+
if (!Number.isFinite(mrNumber) || mrNumber <= 0)
|
|
51
|
+
return null;
|
|
52
|
+
return {
|
|
53
|
+
platform,
|
|
54
|
+
projectPath: slug,
|
|
55
|
+
mrNumber,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=worktree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.js","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/worktree/worktree.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAQrE;;;;;GAKG;AACH,MAAM,UAAU,kBAAkB,CAAC,KAAa;IAC9C,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QAC7C,MAAM,IAAI,KAAK,CAAC,wDAAwD,KAAK,EAAE,CAAC,CAAC;IACnF,CAAC;IACD,OAAO,KAAqB,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,WAAmB;IACpD,OAAO,WAAW,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;AACzC,CAAC;AAED,MAAM,UAAU,2BAA2B,CAAC,QAA0B;IACpE,MAAM,IAAI,GAAG,kBAAkB,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IACtD,OAAO,GAAG,QAAQ,CAAC,QAAQ,IAAI,IAAI,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC;AAC7D,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,QAA0B;IAC3D,OAAO,kBAAkB,CAAC,IAAI,CAAC,iBAAiB,EAAE,2BAA2B,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC5F,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,MAAgB,EAAE,YAAoB,EAAE,QAAgB;IACrF,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;QAC7B,OAAO;YACL,MAAM,EAAE,QAAQ;YAChB,OAAO,EAAE,YAAY;YACrB,WAAW,EAAE,UAAU,YAAY,EAAE;SACtC,CAAC;IACJ,CAAC;IACD,MAAM,WAAW,GAAG,mBAAmB,QAAQ,OAAO,CAAC;IACvD,OAAO;QACL,MAAM,EAAE,MAAM,CAAC,QAAQ;QACvB,OAAO,EAAE,GAAG,YAAY,IAAI,WAAW,EAAE;QACzC,WAAW;KACZ,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,0BAA0B,CACxC,aAAqB;IAErB,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;IAClE,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IACxB,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC;IAC7D,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;IACtB,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;IAC7B,IAAI,IAAI,KAAK,SAAS,IAAI,WAAW,KAAK,SAAS;QAAE,OAAO,IAAI,CAAC;IACjE,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;IAClD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,QAAQ,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAC7D,OAAO;QACL,QAAQ;QACR,WAAW,EAAE,IAAI;QACjB,QAAQ;KACT,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export declare const worktreePlatformSchema: z.ZodEnum<{
|
|
3
|
+
github: "github";
|
|
4
|
+
gitlab: "gitlab";
|
|
5
|
+
}>;
|
|
6
|
+
export type WorktreePlatform = z.infer<typeof worktreePlatformSchema>;
|
|
7
|
+
export declare const worktreeIdentitySchema: z.ZodObject<{
|
|
8
|
+
platform: z.ZodEnum<{
|
|
9
|
+
github: "github";
|
|
10
|
+
gitlab: "gitlab";
|
|
11
|
+
}>;
|
|
12
|
+
projectPath: z.ZodString;
|
|
13
|
+
mrNumber: z.ZodNumber;
|
|
14
|
+
}, z.core.$strip>;
|
|
15
|
+
export type WorktreeIdentity = z.infer<typeof worktreeIdentitySchema>;
|
|
16
|
+
export type WorktreePath = string & {
|
|
17
|
+
readonly __brand: 'WorktreePath';
|
|
18
|
+
};
|
|
19
|
+
export type MrSource = {
|
|
20
|
+
kind: 'origin';
|
|
21
|
+
} | {
|
|
22
|
+
kind: 'fork';
|
|
23
|
+
cloneUrl: string;
|
|
24
|
+
};
|
|
25
|
+
export interface FetchRef {
|
|
26
|
+
remote: string;
|
|
27
|
+
refspec: string;
|
|
28
|
+
worktreeRef: string;
|
|
29
|
+
}
|
|
30
|
+
export interface WorktreeEntry {
|
|
31
|
+
identity: WorktreeIdentity;
|
|
32
|
+
path: WorktreePath;
|
|
33
|
+
mtime: Date;
|
|
34
|
+
}
|
|
35
|
+
export type EnsureResult = {
|
|
36
|
+
status: 'created';
|
|
37
|
+
path: WorktreePath;
|
|
38
|
+
settingsWarning: string | null;
|
|
39
|
+
} | {
|
|
40
|
+
status: 'reused';
|
|
41
|
+
path: WorktreePath;
|
|
42
|
+
} | {
|
|
43
|
+
status: 'failed';
|
|
44
|
+
reason: string;
|
|
45
|
+
};
|
|
46
|
+
export type RemoveResult = {
|
|
47
|
+
status: 'removed';
|
|
48
|
+
} | {
|
|
49
|
+
status: 'absent';
|
|
50
|
+
} | {
|
|
51
|
+
status: 'failed';
|
|
52
|
+
warning: string;
|
|
53
|
+
};
|
|
54
|
+
//# sourceMappingURL=worktree.schema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.schema.d.ts","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/worktree/worktree.schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,sBAAsB;;;EAA+B,CAAC;AACnE,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,sBAAsB,CAAC,CAAC;AAEtE,eAAO,MAAM,sBAAsB;;;;;;;iBAIjC,CAAC;AACH,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,sBAAsB,CAAC,CAAC;AAEtE,MAAM,MAAM,YAAY,GAAG,MAAM,GAAG;IAAE,QAAQ,CAAC,OAAO,EAAE,cAAc,CAAA;CAAE,CAAC;AAEzE,MAAM,MAAM,QAAQ,GAChB;IAAE,IAAI,EAAE,QAAQ,CAAA;CAAE,GAClB;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAEvC,MAAM,WAAW,QAAQ;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,IAAI,EAAE,YAAY,CAAC;IACnB,KAAK,EAAE,IAAI,CAAC;CACb;AAED,MAAM,MAAM,YAAY,GACpB;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,IAAI,EAAE,YAAY,CAAC;IAAC,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,GACzE;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,IAAI,EAAE,YAAY,CAAA;CAAE,GACxC;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AAEzC,MAAM,MAAM,YAAY,GACpB;IAAE,MAAM,EAAE,SAAS,CAAA;CAAE,GACrB;IAAE,MAAM,EAAE,QAAQ,CAAA;CAAE,GACpB;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export const worktreePlatformSchema = z.enum(['gitlab', 'github']);
|
|
3
|
+
export const worktreeIdentitySchema = z.object({
|
|
4
|
+
platform: worktreePlatformSchema,
|
|
5
|
+
projectPath: z.string().min(1),
|
|
6
|
+
mrNumber: z.number().int().positive(),
|
|
7
|
+
});
|
|
8
|
+
//# sourceMappingURL=worktree.schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.schema.js","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/entities/worktree/worktree.schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC;AAGnE,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC7C,QAAQ,EAAE,sBAAsB;IAChC,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9B,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;CACtC,CAAC,CAAC"}
|
package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.d.ts
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { GitCommand, GitCommandExecutor, GitCommandResult } from '../../../../modules/worktree-management/entities/gitCommand/gitCommand.gateway.js';
|
|
2
|
+
export type GitProcessRunner = (command: GitCommand) => Promise<GitCommandResult>;
|
|
3
|
+
export declare class GitCommandCliGateway implements GitCommandExecutor {
|
|
4
|
+
private readonly runner;
|
|
5
|
+
constructor(runner?: GitProcessRunner);
|
|
6
|
+
execute(command: GitCommand): Promise<GitCommandResult>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=gitCommand.cli.gateway.d.ts.map
|
package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitCommand.cli.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,UAAU,EACV,kBAAkB,EAClB,gBAAgB,EACjB,MAAM,yEAAyE,CAAC;AAEjF,MAAM,MAAM,gBAAgB,GAAG,CAAC,OAAO,EAAE,UAAU,KAAK,OAAO,CAAC,gBAAgB,CAAC,CAAC;AAqBlF,qBAAa,oBAAqB,YAAW,kBAAkB;IAC7D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmB;gBAE9B,MAAM,GAAE,gBAAqC;IAInD,OAAO,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAG9D"}
|
package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.js
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { spawn } from 'node:child_process';
|
|
2
|
+
function defaultGitRunner() {
|
|
3
|
+
return async (command) => new Promise((resolve, reject) => {
|
|
4
|
+
const child = spawn('git', command.args, { cwd: command.cwd });
|
|
5
|
+
let stdout = '';
|
|
6
|
+
let stderr = '';
|
|
7
|
+
child.stdout?.on('data', chunk => {
|
|
8
|
+
stdout += chunk.toString();
|
|
9
|
+
});
|
|
10
|
+
child.stderr?.on('data', chunk => {
|
|
11
|
+
stderr += chunk.toString();
|
|
12
|
+
});
|
|
13
|
+
child.on('error', reject);
|
|
14
|
+
child.on('close', code => {
|
|
15
|
+
resolve({ stdout, stderr, exitCode: code ?? -1 });
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
export class GitCommandCliGateway {
|
|
20
|
+
runner;
|
|
21
|
+
constructor(runner = defaultGitRunner()) {
|
|
22
|
+
this.runner = runner;
|
|
23
|
+
}
|
|
24
|
+
async execute(command) {
|
|
25
|
+
return this.runner(command);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=gitCommand.cli.gateway.js.map
|
package/dist/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitCommand.cli.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/interface-adapters/gateways/gitCommand.cli.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAS3C,SAAS,gBAAgB;IACvB,OAAO,KAAK,EAAC,OAAO,EAAC,EAAE,CACrB,IAAI,OAAO,CAAmB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAChD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;QAC/D,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC1B,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE;YACvB,OAAO,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACP,CAAC;AAED,MAAM,OAAO,oBAAoB;IACd,MAAM,CAAmB;IAE1C,YAAY,SAA2B,gBAAgB,EAAE;QACvD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAmB;QAC/B,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;CACF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { EnsureWorktreeRequest, RemoveWorktreeRequest, WorktreeGateway } from '../../../../modules/worktree-management/entities/worktree/worktree.gateway.js';
|
|
2
|
+
import type { EnsureResult, RemoveResult, WorktreeEntry, WorktreeIdentity } from '../../../../modules/worktree-management/entities/worktree/worktree.schema.js';
|
|
3
|
+
import type { GitCommandExecutor } from '../../../../modules/worktree-management/entities/gitCommand/gitCommand.gateway.js';
|
|
4
|
+
export interface WorktreeFileSystemGatewayDependencies {
|
|
5
|
+
executor: GitCommandExecutor;
|
|
6
|
+
baseDirectory?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare class WorktreeFileSystemGateway implements WorktreeGateway {
|
|
9
|
+
private readonly executor;
|
|
10
|
+
private readonly baseDirectory;
|
|
11
|
+
constructor(deps: WorktreeFileSystemGatewayDependencies);
|
|
12
|
+
ensure(request: EnsureWorktreeRequest): Promise<EnsureResult>;
|
|
13
|
+
remove(request: RemoveWorktreeRequest): Promise<RemoveResult>;
|
|
14
|
+
exists(identity: WorktreeIdentity): Promise<boolean>;
|
|
15
|
+
list(): Promise<WorktreeEntry[]>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=worktree.fileSystem.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.fileSystem.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EACV,qBAAqB,EACrB,qBAAqB,EACrB,eAAe,EAChB,MAAM,qEAAqE,CAAC;AAC7E,OAAO,KAAK,EACV,YAAY,EACZ,YAAY,EACZ,aAAa,EACb,gBAAgB,EACjB,MAAM,oEAAoE,CAAC;AAI5E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yEAAyE,CAAC;AAElH,MAAM,WAAW,qCAAqC;IACpD,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,qBAAa,yBAA0B,YAAW,eAAe;IAC/D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAqB;IAC9C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;gBAE3B,IAAI,EAAE,qCAAqC;IAKjD,MAAM,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,YAAY,CAAC;IAiB7D,MAAM,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,YAAY,CAAC;IAe7D,MAAM,CAAC,QAAQ,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;IAIpD,IAAI,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;CAoBvC"}
|
package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.js
ADDED
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { existsSync, mkdirSync, readdirSync, statSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import { WORKTREE_BASE_DIR } from '../../../../shared/services/daemonPaths.js';
|
|
4
|
+
import { createWorktreePath, deriveWorktreePath, parseWorktreeDirectoryName, } from '../../../../modules/worktree-management/entities/worktree/worktree.js';
|
|
5
|
+
import { ensureWorktree } from '../../../../modules/worktree-management/usecases/ensureWorktree.usecase.js';
|
|
6
|
+
import { removeWorktree } from '../../../../modules/worktree-management/usecases/removeWorktree.usecase.js';
|
|
7
|
+
import { writeWorktreeSettings } from '../../../../modules/worktree-management/services/worktreeSettingsWriter.js';
|
|
8
|
+
export class WorktreeFileSystemGateway {
|
|
9
|
+
executor;
|
|
10
|
+
baseDirectory;
|
|
11
|
+
constructor(deps) {
|
|
12
|
+
this.executor = deps.executor;
|
|
13
|
+
this.baseDirectory = deps.baseDirectory ?? WORKTREE_BASE_DIR;
|
|
14
|
+
}
|
|
15
|
+
async ensure(request) {
|
|
16
|
+
mkdirSync(this.baseDirectory, { recursive: true });
|
|
17
|
+
return ensureWorktree({
|
|
18
|
+
identity: request.identity,
|
|
19
|
+
sourceBranch: request.sourceBranch,
|
|
20
|
+
source: request.source,
|
|
21
|
+
sourceCheckoutPath: request.sourceCheckoutPath,
|
|
22
|
+
}, {
|
|
23
|
+
executor: this.executor,
|
|
24
|
+
worktreeExists: async (path) => existsSync(path),
|
|
25
|
+
writeWorktreeSettings,
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
async remove(request) {
|
|
29
|
+
try {
|
|
30
|
+
return await removeWorktree({ identity: request.identity, sourceCheckoutPath: request.sourceCheckoutPath }, {
|
|
31
|
+
executor: this.executor,
|
|
32
|
+
worktreeExists: async (path) => existsSync(path),
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
37
|
+
return { status: 'failed', warning: message };
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
async exists(identity) {
|
|
41
|
+
return existsSync(deriveWorktreePath(identity));
|
|
42
|
+
}
|
|
43
|
+
async list() {
|
|
44
|
+
if (!existsSync(this.baseDirectory)) {
|
|
45
|
+
return [];
|
|
46
|
+
}
|
|
47
|
+
const directories = readdirSync(this.baseDirectory, { withFileTypes: true });
|
|
48
|
+
const entries = [];
|
|
49
|
+
for (const dirent of directories) {
|
|
50
|
+
if (!dirent.isDirectory())
|
|
51
|
+
continue;
|
|
52
|
+
const identity = parseWorktreeDirectoryName(dirent.name);
|
|
53
|
+
if (identity === null)
|
|
54
|
+
continue;
|
|
55
|
+
const path = createWorktreePath(join(this.baseDirectory, dirent.name));
|
|
56
|
+
try {
|
|
57
|
+
const stats = statSync(path);
|
|
58
|
+
entries.push({ identity, path, mtime: stats.mtime });
|
|
59
|
+
}
|
|
60
|
+
catch {
|
|
61
|
+
// ignore worktrees whose stat fails (transient FS errors, race with removal)
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return entries;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=worktree.fileSystem.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktree.fileSystem.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { WorktreePath } from '../../../modules/worktree-management/entities/worktree/worktree.schema.js';
|
|
2
|
+
import type { WorktreeSettingsWriteResult } from '../../../modules/worktree-management/usecases/ensureWorktree.usecase.js';
|
|
3
|
+
export declare function writeWorktreeSettings(worktreePath: WorktreePath): Promise<WorktreeSettingsWriteResult>;
|
|
4
|
+
//# sourceMappingURL=worktreeSettingsWriter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktreeSettingsWriter.d.ts","sourceRoot":"","sources":["../../../../src/modules/worktree-management/services/worktreeSettingsWriter.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oEAAoE,CAAC;AACvG,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,kEAAkE,CAAC;AAIpH,wBAAsB,qBAAqB,CACzC,YAAY,EAAE,YAAY,GACzB,OAAO,CAAC,2BAA2B,CAAC,CAUtC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { mkdirSync, writeFileSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
const settingsContent = JSON.stringify({ worktree: { bgIsolation: 'none' } }, null, 2);
|
|
4
|
+
export async function writeWorktreeSettings(worktreePath) {
|
|
5
|
+
try {
|
|
6
|
+
const claudeDirectory = join(worktreePath, '.claude');
|
|
7
|
+
mkdirSync(claudeDirectory, { recursive: true });
|
|
8
|
+
writeFileSync(join(claudeDirectory, 'settings.json'), settingsContent);
|
|
9
|
+
return { status: 'ok' };
|
|
10
|
+
}
|
|
11
|
+
catch (error) {
|
|
12
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
13
|
+
return { status: 'failed', reason: message };
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=worktreeSettingsWriter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktreeSettingsWriter.js","sourceRoot":"","sources":["../../../../src/modules/worktree-management/services/worktreeSettingsWriter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC,MAAM,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAEvF,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,YAA0B;IAE1B,IAAI,CAAC;QACH,MAAM,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC;QACtD,SAAS,CAAC,eAAe,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAChD,aAAa,CAAC,IAAI,CAAC,eAAe,EAAE,eAAe,CAAC,EAAE,eAAe,CAAC,CAAC;QACvE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IAC1B,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACvE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;IAC/C,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { EnsureResult, MrSource, WorktreeIdentity, WorktreePath } from '../../../modules/worktree-management/entities/worktree/worktree.schema.js';
|
|
2
|
+
import type { GitCommandExecutor } from '../../../modules/worktree-management/entities/gitCommand/gitCommand.gateway.js';
|
|
3
|
+
export interface EnsureWorktreeInput {
|
|
4
|
+
identity: WorktreeIdentity;
|
|
5
|
+
sourceBranch: string;
|
|
6
|
+
source: MrSource;
|
|
7
|
+
sourceCheckoutPath: string;
|
|
8
|
+
}
|
|
9
|
+
export interface WorktreeSettingsWriteResult {
|
|
10
|
+
status: 'ok' | 'failed';
|
|
11
|
+
reason?: string;
|
|
12
|
+
}
|
|
13
|
+
export interface EnsureWorktreeDependencies {
|
|
14
|
+
executor: GitCommandExecutor;
|
|
15
|
+
worktreeExists: (path: WorktreePath) => Promise<boolean>;
|
|
16
|
+
writeWorktreeSettings: (path: WorktreePath) => Promise<WorktreeSettingsWriteResult>;
|
|
17
|
+
}
|
|
18
|
+
export declare function ensureWorktree(input: EnsureWorktreeInput, deps: EnsureWorktreeDependencies): Promise<EnsureResult>;
|
|
19
|
+
//# sourceMappingURL=ensureWorktree.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ensureWorktree.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/worktree-management/usecases/ensureWorktree.usecase.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,YAAY,EACZ,QAAQ,EACR,gBAAgB,EAChB,YAAY,EACb,MAAM,oEAAoE,CAAC;AAC5E,OAAO,KAAK,EACV,kBAAkB,EAEnB,MAAM,yEAAyE,CAAC;AAEjF,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,YAAY,EAAE,MAAM,CAAC;IACrB,MAAM,EAAE,QAAQ,CAAC;IACjB,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE,IAAI,GAAG,QAAQ,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,0BAA0B;IACzC,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,cAAc,EAAE,CAAC,IAAI,EAAE,YAAY,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IACzD,qBAAqB,EAAE,CAAC,IAAI,EAAE,YAAY,KAAK,OAAO,CAAC,2BAA2B,CAAC,CAAC;CACrF;AAMD,wBAAsB,cAAc,CAClC,KAAK,EAAE,mBAAmB,EAC1B,IAAI,EAAE,0BAA0B,GAC/B,OAAO,CAAC,YAAY,CAAC,CAyDvB"}
|