@doingdev/opencode-claude-manager-plugin 0.1.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/README.md +119 -0
- package/dist/claude/claude-agent-sdk-adapter.d.ts +24 -0
- package/dist/claude/claude-agent-sdk-adapter.js +256 -0
- package/dist/claude/claude-session.service.d.ts +15 -0
- package/dist/claude/claude-session.service.js +23 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +12 -0
- package/dist/manager/manager-orchestrator.d.ts +18 -0
- package/dist/manager/manager-orchestrator.js +186 -0
- package/dist/manager/task-planner.d.ts +5 -0
- package/dist/manager/task-planner.js +42 -0
- package/dist/metadata/claude-metadata.service.d.ts +12 -0
- package/dist/metadata/claude-metadata.service.js +38 -0
- package/dist/metadata/repo-claude-config-reader.d.ts +7 -0
- package/dist/metadata/repo-claude-config-reader.js +154 -0
- package/dist/plugin/claude-manager.plugin.d.ts +2 -0
- package/dist/plugin/claude-manager.plugin.js +102 -0
- package/dist/plugin/service-factory.d.ts +7 -0
- package/dist/plugin/service-factory.js +25 -0
- package/dist/prompts/registry.d.ts +2 -0
- package/dist/prompts/registry.js +11 -0
- package/dist/state/file-run-state-store.d.ts +14 -0
- package/dist/state/file-run-state-store.js +97 -0
- package/dist/types/contracts.d.ts +145 -0
- package/dist/types/contracts.js +1 -0
- package/dist/worktree/worktree-coordinator.d.ts +21 -0
- package/dist/worktree/worktree-coordinator.js +64 -0
- package/package.json +55 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { WorktreeAssignment } from '../types/contracts.js';
|
|
2
|
+
export interface GitCommandRunner {
|
|
3
|
+
run(args: string[], cwd: string): Promise<{
|
|
4
|
+
stdout: string;
|
|
5
|
+
stderr: string;
|
|
6
|
+
}>;
|
|
7
|
+
}
|
|
8
|
+
export declare class WorktreeCoordinator {
|
|
9
|
+
private readonly gitRunner;
|
|
10
|
+
private readonly storageDirectoryName;
|
|
11
|
+
constructor(gitRunner?: GitCommandRunner, storageDirectoryName?: string);
|
|
12
|
+
prepareAssignment(input: {
|
|
13
|
+
cwd: string;
|
|
14
|
+
runId: string;
|
|
15
|
+
title: string;
|
|
16
|
+
useWorktree: boolean;
|
|
17
|
+
}): Promise<WorktreeAssignment>;
|
|
18
|
+
cleanupAssignment(assignment: WorktreeAssignment): Promise<void>;
|
|
19
|
+
isGitRepository(cwd: string): Promise<boolean>;
|
|
20
|
+
private getRepositoryRoot;
|
|
21
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { execFile } from 'node:child_process';
|
|
2
|
+
import { promises as fs } from 'node:fs';
|
|
3
|
+
import path from 'node:path';
|
|
4
|
+
import { promisify } from 'node:util';
|
|
5
|
+
const execFileAsync = promisify(execFile);
|
|
6
|
+
const defaultGitRunner = {
|
|
7
|
+
run(args, cwd) {
|
|
8
|
+
return execFileAsync('git', args, { cwd });
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
export class WorktreeCoordinator {
|
|
12
|
+
gitRunner;
|
|
13
|
+
storageDirectoryName;
|
|
14
|
+
constructor(gitRunner = defaultGitRunner, storageDirectoryName = '.claude-manager') {
|
|
15
|
+
this.gitRunner = gitRunner;
|
|
16
|
+
this.storageDirectoryName = storageDirectoryName;
|
|
17
|
+
}
|
|
18
|
+
async prepareAssignment(input) {
|
|
19
|
+
const repositoryRoot = await this.getRepositoryRoot(input.cwd);
|
|
20
|
+
if (!input.useWorktree || !repositoryRoot) {
|
|
21
|
+
return {
|
|
22
|
+
mode: 'shared-root',
|
|
23
|
+
cwd: input.cwd,
|
|
24
|
+
rootCwd: input.cwd,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
const slug = sanitizeSlug(input.title);
|
|
28
|
+
const branchName = `claude-manager/${input.runId}-${slug}`;
|
|
29
|
+
const worktreePath = path.join(repositoryRoot, this.storageDirectoryName, 'worktrees', input.runId, slug);
|
|
30
|
+
await fs.mkdir(path.dirname(worktreePath), { recursive: true });
|
|
31
|
+
await this.gitRunner.run(['worktree', 'add', worktreePath, '-b', branchName], repositoryRoot);
|
|
32
|
+
return {
|
|
33
|
+
mode: 'git-worktree',
|
|
34
|
+
cwd: worktreePath,
|
|
35
|
+
rootCwd: repositoryRoot,
|
|
36
|
+
branchName,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
async cleanupAssignment(assignment) {
|
|
40
|
+
if (assignment.mode !== 'git-worktree') {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
await this.gitRunner.run(['worktree', 'remove', '--force', assignment.cwd], assignment.rootCwd);
|
|
44
|
+
}
|
|
45
|
+
async isGitRepository(cwd) {
|
|
46
|
+
return (await this.getRepositoryRoot(cwd)) !== null;
|
|
47
|
+
}
|
|
48
|
+
async getRepositoryRoot(cwd) {
|
|
49
|
+
try {
|
|
50
|
+
const result = await this.gitRunner.run(['rev-parse', '--show-toplevel'], cwd);
|
|
51
|
+
return result.stdout.trim() || null;
|
|
52
|
+
}
|
|
53
|
+
catch {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
function sanitizeSlug(value) {
|
|
59
|
+
return (value
|
|
60
|
+
.toLowerCase()
|
|
61
|
+
.replace(/[^a-z0-9]+/g, '-')
|
|
62
|
+
.replace(/^-+|-+$/g, '')
|
|
63
|
+
.slice(0, 40) || 'task');
|
|
64
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@doingdev/opencode-claude-manager-plugin",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "OpenCode plugin that orchestrates Claude Code sessions.",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"opencode",
|
|
7
|
+
"plugin",
|
|
8
|
+
"claude",
|
|
9
|
+
"agent",
|
|
10
|
+
"automation"
|
|
11
|
+
],
|
|
12
|
+
"type": "module",
|
|
13
|
+
"main": "./dist/index.js",
|
|
14
|
+
"types": "./dist/index.d.ts",
|
|
15
|
+
"exports": {
|
|
16
|
+
".": {
|
|
17
|
+
"types": "./dist/index.d.ts",
|
|
18
|
+
"import": "./dist/index.js"
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
"files": [
|
|
22
|
+
"dist",
|
|
23
|
+
"README.md"
|
|
24
|
+
],
|
|
25
|
+
"publishConfig": {
|
|
26
|
+
"access": "public"
|
|
27
|
+
},
|
|
28
|
+
"scripts": {
|
|
29
|
+
"build": "tsc -p tsconfig.build.json",
|
|
30
|
+
"typecheck": "tsc -p tsconfig.json --noEmit",
|
|
31
|
+
"lint": "eslint .",
|
|
32
|
+
"format": "prettier --write .",
|
|
33
|
+
"test": "vitest run"
|
|
34
|
+
},
|
|
35
|
+
"engines": {
|
|
36
|
+
"node": ">=22.0.0"
|
|
37
|
+
},
|
|
38
|
+
"dependencies": {
|
|
39
|
+
"@anthropic-ai/claude-agent-sdk": "^0.2.81",
|
|
40
|
+
"@opencode-ai/plugin": "^1.2.27",
|
|
41
|
+
"json5": "^2.2.3",
|
|
42
|
+
"zod": "^4.1.8"
|
|
43
|
+
},
|
|
44
|
+
"devDependencies": {
|
|
45
|
+
"@eslint/js": "^9.22.0",
|
|
46
|
+
"@types/node": "^24.5.2",
|
|
47
|
+
"@vitest/coverage-v8": "^4.1.0",
|
|
48
|
+
"eslint": "^9.22.0",
|
|
49
|
+
"globals": "^15.15.0",
|
|
50
|
+
"prettier": "^3.8.1",
|
|
51
|
+
"typescript": "^5.9.3",
|
|
52
|
+
"typescript-eslint": "^8.57.1",
|
|
53
|
+
"vitest": "^4.1.0"
|
|
54
|
+
}
|
|
55
|
+
}
|