@adamancyzhang/claude-orchestrator 0.3.1 → 0.3.3
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 +76 -77
- package/dist/cli/commands.d.ts +2 -2
- package/dist/cli/commands.js +51 -24
- package/dist/cli/commands.js.map +1 -1
- package/dist/config.d.ts +8 -2
- package/dist/config.js +6 -2
- package/dist/config.js.map +1 -1
- package/dist/executor/runner.d.ts +19 -0
- package/dist/executor/runner.js +59 -0
- package/dist/executor/runner.js.map +1 -0
- package/dist/executor/template.d.ts +12 -0
- package/dist/executor/template.js +42 -0
- package/dist/executor/template.js.map +1 -0
- package/dist/hooks/engine.d.ts +22 -0
- package/dist/hooks/engine.js +50 -0
- package/dist/hooks/engine.js.map +1 -0
- package/dist/index.js +16 -15
- package/dist/index.js.map +1 -1
- package/dist/leader/chain-router.d.ts +22 -0
- package/dist/leader/chain-router.js +163 -0
- package/dist/leader/chain-router.js.map +1 -0
- package/dist/leader/event-bus.d.ts +1 -1
- package/dist/leader/event-bus.js +1 -1
- package/dist/leader/event-bus.js.map +1 -1
- package/dist/leader/index.d.ts +1 -2
- package/dist/leader/index.js +30 -18
- package/dist/leader/index.js.map +1 -1
- package/dist/leader/state.js +9 -0
- package/dist/leader/state.js.map +1 -1
- package/dist/leader/tui.d.ts +8 -0
- package/dist/leader/tui.js +66 -4
- package/dist/leader/tui.js.map +1 -1
- package/dist/leader/watcher.d.ts +4 -5
- package/dist/leader/watcher.js +8 -25
- package/dist/leader/watcher.js.map +1 -1
- package/dist/models/schemas.d.ts +256 -0
- package/dist/models/schemas.js +25 -0
- package/dist/models/schemas.js.map +1 -1
- package/dist/skills/CLAUDE.md +1 -1
- package/dist/skills/claude-orchestrator/SKILL.md +124 -60
- package/dist/templates/{leader-decompose.md → worker-decompose.md} +6 -8
- package/dist/templates/worker-evaluate.md +41 -0
- package/dist/utils/exec.js +2 -0
- package/dist/utils/exec.js.map +1 -1
- package/dist/utils/logger.d.ts +10 -0
- package/dist/utils/logger.js +22 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/worker/evaluator.d.ts +13 -0
- package/dist/worker/evaluator.js +112 -0
- package/dist/worker/evaluator.js.map +1 -0
- package/dist/worker/watcher.d.ts +11 -5
- package/dist/worker/watcher.js +98 -84
- package/dist/worker/watcher.js.map +1 -1
- package/package.json +1 -1
- package/dist/leader/decision-engine.d.ts +0 -35
- package/dist/leader/decision-engine.js +0 -102
- package/dist/leader/decision-engine.js.map +0 -1
- package/dist/leader/task-generator.d.ts +0 -34
- package/dist/leader/task-generator.js +0 -93
- package/dist/leader/task-generator.js.map +0 -1
- package/dist/templates/leader-decide.md +0 -59
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { execWithTee } from "../utils/exec.js";
|
|
4
|
+
import { expandHomeDir } from "../config.js";
|
|
5
|
+
import { Logger } from "../utils/logger.js";
|
|
6
|
+
export class ClaudeRunner {
|
|
7
|
+
command;
|
|
8
|
+
cacheDir;
|
|
9
|
+
leaderInstanceId;
|
|
10
|
+
workDir;
|
|
11
|
+
logger = new Logger("ClaudeRunner");
|
|
12
|
+
resolvedCache;
|
|
13
|
+
constructor(command, cacheDir, leaderInstanceId, workDir) {
|
|
14
|
+
this.command = command;
|
|
15
|
+
this.cacheDir = cacheDir;
|
|
16
|
+
this.leaderInstanceId = leaderInstanceId;
|
|
17
|
+
this.workDir = workDir;
|
|
18
|
+
this.resolvedCache = expandHomeDir(path.join(this.cacheDir, this.leaderInstanceId));
|
|
19
|
+
}
|
|
20
|
+
dateDir() {
|
|
21
|
+
return new Date().toISOString().slice(0, 10);
|
|
22
|
+
}
|
|
23
|
+
ensureDir(dir) {
|
|
24
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
25
|
+
}
|
|
26
|
+
taskDocPath(taskId) {
|
|
27
|
+
const dir = path.join(this.resolvedCache, "tasks", this.dateDir());
|
|
28
|
+
this.ensureDir(dir);
|
|
29
|
+
return path.join(dir, `${taskId}.md`);
|
|
30
|
+
}
|
|
31
|
+
logPath(uniqueKey) {
|
|
32
|
+
const dir = path.join(this.resolvedCache, "logs", this.dateDir());
|
|
33
|
+
this.ensureDir(dir);
|
|
34
|
+
return path.join(dir, `${uniqueKey}.log`);
|
|
35
|
+
}
|
|
36
|
+
resultPath(uniqueKey) {
|
|
37
|
+
const dir = path.join(this.resolvedCache, "results", this.dateDir());
|
|
38
|
+
this.ensureDir(dir);
|
|
39
|
+
return path.join(dir, `${uniqueKey}-result.md`);
|
|
40
|
+
}
|
|
41
|
+
evalLogPath(uniqueKey) {
|
|
42
|
+
const dir = path.join(this.resolvedCache, "eval", this.dateDir());
|
|
43
|
+
this.ensureDir(dir);
|
|
44
|
+
return path.join(dir, `${uniqueKey}-eval.log`);
|
|
45
|
+
}
|
|
46
|
+
evalResultPath(uniqueKey) {
|
|
47
|
+
const dir = path.join(this.resolvedCache, "eval", this.dateDir());
|
|
48
|
+
this.ensureDir(dir);
|
|
49
|
+
return path.join(dir, `${uniqueKey}-eval-result.md`);
|
|
50
|
+
}
|
|
51
|
+
async run(prompt, logPath) {
|
|
52
|
+
if (Logger.isDebug()) {
|
|
53
|
+
this.logger.debug(`Prompt (${prompt.length} chars):\n${prompt.slice(0, 1000)}${prompt.length > 1000 ? "\n... (truncated)" : ""}`);
|
|
54
|
+
this.logger.debug(`Log: ${logPath}`);
|
|
55
|
+
}
|
|
56
|
+
return execWithTee(this.command, prompt, logPath, this.workDir);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runner.js","sourceRoot":"","sources":["../../src/executor/runner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare const LINK_TEMPLATES: string[];
|
|
2
|
+
export declare class TemplateEngine {
|
|
3
|
+
private agentsDir;
|
|
4
|
+
private templates;
|
|
5
|
+
private logger;
|
|
6
|
+
constructor(agentsDir: string);
|
|
7
|
+
loadAll(): Promise<void>;
|
|
8
|
+
get(link: string): string | undefined;
|
|
9
|
+
loadFile(filename: string): Promise<string>;
|
|
10
|
+
render(template: string, vars: Record<string, string>): string;
|
|
11
|
+
}
|
|
12
|
+
export { LINK_TEMPLATES };
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { Logger } from "../utils/logger.js";
|
|
4
|
+
const LINK_TEMPLATES = ["plan", "build", "verify", "review", "accept", "decompose"];
|
|
5
|
+
export class TemplateEngine {
|
|
6
|
+
agentsDir;
|
|
7
|
+
templates = {};
|
|
8
|
+
logger = new Logger("TemplateEngine");
|
|
9
|
+
constructor(agentsDir) {
|
|
10
|
+
this.agentsDir = agentsDir;
|
|
11
|
+
}
|
|
12
|
+
async loadAll() {
|
|
13
|
+
for (const link of LINK_TEMPLATES) {
|
|
14
|
+
try {
|
|
15
|
+
this.templates[link] = await fs.promises.readFile(path.join(this.agentsDir, `worker-${link}.md`), "utf-8");
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
this.templates[link] = `You are a Worker.\n\n## Task\n\n{{content}}`;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
get(link) {
|
|
23
|
+
return this.templates[link];
|
|
24
|
+
}
|
|
25
|
+
async loadFile(filename) {
|
|
26
|
+
try {
|
|
27
|
+
return await fs.promises.readFile(path.join(this.agentsDir, filename), "utf-8");
|
|
28
|
+
}
|
|
29
|
+
catch {
|
|
30
|
+
throw new Error(`Template ${filename} not found in ${this.agentsDir}`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
render(template, vars) {
|
|
34
|
+
let result = template;
|
|
35
|
+
for (const [key, value] of Object.entries(vars)) {
|
|
36
|
+
result = result.replace(new RegExp(`\\{\\{${key}\\}\\}`, "g"), value);
|
|
37
|
+
}
|
|
38
|
+
return result;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
export { LINK_TEMPLATES };
|
|
42
|
+
//# sourceMappingURL=template.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"template.js","sourceRoot":"","sources":["../../src/executor/template.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAC9B,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,MAAM,cAAc,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;AAEpF,MAAM,OAAO,cAAc;IAIL;IAHZ,SAAS,GAA2B,EAAE,CAAC;IACvC,MAAM,GAAG,IAAI,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAE9C,YAAoB,SAAiB;QAAjB,cAAS,GAAT,SAAS,CAAQ;IAAG,CAAC;IAEzC,KAAK,CAAC,OAAO;QACX,KAAK,MAAM,IAAI,IAAI,cAAc,EAAE,CAAC;YAClC,IAAI,CAAC;gBACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAC/C,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,UAAU,IAAI,KAAK,CAAC,EAAE,OAAO,CACxD,CAAC;YACJ,CAAC;YAAC,MAAM,CAAC;gBACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,6CAA6C,CAAC;YACvE,CAAC;QACH,CAAC;IACH,CAAC;IAED,GAAG,CAAC,IAAY;QACd,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,QAAgB;QAC7B,IAAI,CAAC;YACH,OAAO,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAC/B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,OAAO,CAC7C,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,YAAY,QAAQ,iBAAiB,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;IAED,MAAM,CAAC,QAAgB,EAAE,IAA4B;QACnD,IAAI,MAAM,GAAG,QAAQ,CAAC;QACtB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,SAAS,GAAG,QAAQ,EAAE,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;QACxE,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAED,OAAO,EAAE,cAAc,EAAE,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export interface HookContext {
|
|
2
|
+
instanceId: string;
|
|
3
|
+
instanceName: string;
|
|
4
|
+
instanceRole: string;
|
|
5
|
+
messageId: string;
|
|
6
|
+
messageType: string;
|
|
7
|
+
messageContent: string;
|
|
8
|
+
fromInstance: string;
|
|
9
|
+
fromName: string;
|
|
10
|
+
toInstance: string;
|
|
11
|
+
workDir: string;
|
|
12
|
+
link: string | null;
|
|
13
|
+
logPath?: string;
|
|
14
|
+
exitCode?: number;
|
|
15
|
+
}
|
|
16
|
+
export type HookEvent = "leader_message_start" | "leader_message_end" | "worker_message_start" | "worker_message_end";
|
|
17
|
+
export declare class HookEngine {
|
|
18
|
+
private hooks;
|
|
19
|
+
load(config: Partial<Record<HookEvent, string | null>>): void;
|
|
20
|
+
fire(event: HookEvent, ctx: HookContext): void;
|
|
21
|
+
get registered(): HookEvent[];
|
|
22
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { spawn } from "node:child_process";
|
|
2
|
+
import { Logger } from "../utils/logger.js";
|
|
3
|
+
const logger = new Logger("HookEngine");
|
|
4
|
+
export class HookEngine {
|
|
5
|
+
hooks = new Map();
|
|
6
|
+
load(config) {
|
|
7
|
+
for (const [event, script] of Object.entries(config)) {
|
|
8
|
+
if (script) {
|
|
9
|
+
this.hooks.set(event, script);
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
this.hooks.delete(event);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
fire(event, ctx) {
|
|
17
|
+
const script = this.hooks.get(event);
|
|
18
|
+
if (!script)
|
|
19
|
+
return;
|
|
20
|
+
const env = {
|
|
21
|
+
CO_HOOK_EVENT: event,
|
|
22
|
+
CO_INSTANCE_ID: ctx.instanceId,
|
|
23
|
+
CO_INSTANCE_NAME: ctx.instanceName,
|
|
24
|
+
CO_INSTANCE_ROLE: ctx.instanceRole,
|
|
25
|
+
CO_MESSAGE_ID: ctx.messageId,
|
|
26
|
+
CO_MESSAGE_TYPE: ctx.messageType,
|
|
27
|
+
CO_MESSAGE_CONTENT: ctx.messageContent,
|
|
28
|
+
CO_FROM_INSTANCE: ctx.fromInstance,
|
|
29
|
+
CO_FROM_NAME: ctx.fromName,
|
|
30
|
+
CO_TO_INSTANCE: ctx.toInstance,
|
|
31
|
+
CO_WORK_DIR: ctx.workDir,
|
|
32
|
+
CO_LINK: ctx.link ?? "",
|
|
33
|
+
CO_LOG_PATH: ctx.logPath ?? "",
|
|
34
|
+
CO_EXIT_CODE: ctx.exitCode?.toString() ?? "",
|
|
35
|
+
};
|
|
36
|
+
const child = spawn("sh", ["-c", script], {
|
|
37
|
+
env: { ...process.env, ...env },
|
|
38
|
+
stdio: "ignore",
|
|
39
|
+
detached: true,
|
|
40
|
+
});
|
|
41
|
+
child.on("error", (err) => {
|
|
42
|
+
logger.error(`${event} hook failed`, err);
|
|
43
|
+
});
|
|
44
|
+
child.unref();
|
|
45
|
+
}
|
|
46
|
+
get registered() {
|
|
47
|
+
return Array.from(this.hooks.keys());
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../../src/hooks/engine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,YAAY,CAAC,CAAC;AAoBxC,MAAM,OAAO,UAAU;IACb,KAAK,GAAG,IAAI,GAAG,EAAqB,CAAC;IAE7C,IAAI,CAAC,MAAiD;QACpD,KAAK,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YACrD,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAkB,EAAE,MAAM,CAAC,CAAC;YAC7C,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAkB,CAAC,CAAC;YACxC,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,CAAC,KAAgB,EAAE,GAAgB;QACrC,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,MAAM,GAAG,GAA2B;YAClC,aAAa,EAAE,KAAK;YACpB,cAAc,EAAE,GAAG,CAAC,UAAU;YAC9B,gBAAgB,EAAE,GAAG,CAAC,YAAY;YAClC,gBAAgB,EAAE,GAAG,CAAC,YAAY;YAClC,aAAa,EAAE,GAAG,CAAC,SAAS;YAC5B,eAAe,EAAE,GAAG,CAAC,WAAW;YAChC,kBAAkB,EAAE,GAAG,CAAC,cAAc;YACtC,gBAAgB,EAAE,GAAG,CAAC,YAAY;YAClC,YAAY,EAAE,GAAG,CAAC,QAAQ;YAC1B,cAAc,EAAE,GAAG,CAAC,UAAU;YAC9B,WAAW,EAAE,GAAG,CAAC,OAAO;YACxB,OAAO,EAAE,GAAG,CAAC,IAAI,IAAI,EAAE;YACvB,WAAW,EAAE,GAAG,CAAC,OAAO,IAAI,EAAE;YAC9B,YAAY,EAAE,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE;SAC7C,CAAC;QAEF,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE;YACxC,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE,GAAG,GAAG,EAAE;YAC/B,KAAK,EAAE,QAAQ;YACf,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC;QAEH,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;YACxB,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,cAAc,EAAE,GAAG,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,KAAK,EAAE,CAAC;IAChB,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC;CACF"}
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { Command } from "commander";
|
|
3
3
|
import { loadConfig, loadInstanceConfig } from "./config.js";
|
|
4
|
+
import { Logger } from "./utils/logger.js";
|
|
4
5
|
import { cmdRegister, cmdPushTask, cmdClaimTask, cmdCompleteTask, cmdPollTask, cmdSendMessage, cmdPollMessage, cmdDeleteMessage, cmdUnregister, cmdSetup, cmdTaskBlock, cmdTaskFail, cmdTaskRetry, } from "./cli/commands.js";
|
|
5
6
|
import { output } from "./utils/output.js";
|
|
6
7
|
import { readFileSync } from "node:fs";
|
|
@@ -13,10 +14,14 @@ program
|
|
|
13
14
|
.name("claude-orchestrator")
|
|
14
15
|
.description("Multi-agent orchestration CLI backed by ZooKeeper")
|
|
15
16
|
.version(pkg.version)
|
|
16
|
-
.option("-z, --zookeeper <hosts>", "ZooKeeper connection string (env: ZK_HOSTS)", "127.0.0.1:2181")
|
|
17
|
+
.option("-z, --zookeeper <hosts>", "ZooKeeper connection string (env: ZK_HOSTS)", "127.0.0.1:2181")
|
|
18
|
+
.option("-d, --debug", "Enable debug mode (trace prompts and execution details)");
|
|
17
19
|
function getZkHosts(cmd) {
|
|
18
20
|
return cmd.optsWithGlobals().zookeeper || "127.0.0.1:2181";
|
|
19
21
|
}
|
|
22
|
+
function getDebug(cmd) {
|
|
23
|
+
return !!cmd.optsWithGlobals().debug;
|
|
24
|
+
}
|
|
20
25
|
function getSubOpts(cmd) {
|
|
21
26
|
return cmd.opts();
|
|
22
27
|
}
|
|
@@ -28,14 +33,16 @@ program
|
|
|
28
33
|
.option("--name <name>", "Leader display name")
|
|
29
34
|
.action(async function () {
|
|
30
35
|
const { name } = getSubOpts(this);
|
|
36
|
+
const debug = getDebug(this);
|
|
37
|
+
if (debug)
|
|
38
|
+
Logger.enableDebug();
|
|
31
39
|
const config = loadConfig({ zookeeper: getZkHosts(this) });
|
|
32
40
|
const { startLeader } = await import("./leader/index.js");
|
|
33
41
|
await startLeader({
|
|
34
42
|
zkHosts: config.zk.url,
|
|
35
43
|
name,
|
|
36
44
|
instanceId: config.instanceId,
|
|
37
|
-
|
|
38
|
-
cacheDir: config.cacheDir,
|
|
45
|
+
debug,
|
|
39
46
|
});
|
|
40
47
|
});
|
|
41
48
|
program
|
|
@@ -43,7 +50,8 @@ program
|
|
|
43
50
|
.description("Register as Worker and listen for messages (Ctrl+C to stop)")
|
|
44
51
|
.action(async function () {
|
|
45
52
|
try {
|
|
46
|
-
|
|
53
|
+
const debug = getDebug(this);
|
|
54
|
+
await cmdRegister(getZkHosts(this), debug);
|
|
47
55
|
}
|
|
48
56
|
catch (e) {
|
|
49
57
|
output({ error: String(e) }, true);
|
|
@@ -73,7 +81,7 @@ program
|
|
|
73
81
|
global: {
|
|
74
82
|
cache_dir: config.cacheDir,
|
|
75
83
|
"commands.claude-cli": config.cliCommand,
|
|
76
|
-
|
|
84
|
+
hooks: config.hooks,
|
|
77
85
|
},
|
|
78
86
|
project: {
|
|
79
87
|
name: projectConfig.name || "(not set)",
|
|
@@ -98,20 +106,13 @@ program
|
|
|
98
106
|
// ── Message Commands ──
|
|
99
107
|
program
|
|
100
108
|
.command("send-message")
|
|
101
|
-
.description("Send a message to
|
|
109
|
+
.description("Send a message to the leader instance")
|
|
102
110
|
.requiredOption("--content <text>", "Message content")
|
|
103
|
-
.option("--to <id>", "Recipient instance ID")
|
|
104
|
-
.option("--to-name <name>", "Recipient instance name (e.g. @Tom, @All)")
|
|
105
|
-
.option("--broadcast", "Send to all instances", false)
|
|
106
|
-
.option("--request-help", "Send as a help request", false)
|
|
107
111
|
.option("--instance-id <id>", "Sender instance ID (default from project config)")
|
|
108
112
|
.action(async function () {
|
|
109
113
|
try {
|
|
110
|
-
const { content,
|
|
111
|
-
|
|
112
|
-
throw new Error("Must specify --to, --to-name, --broadcast, or --request-help");
|
|
113
|
-
}
|
|
114
|
-
await cmdSendMessage(getZkHosts(this), instanceId, content, to, broadcast, toName, requestHelp);
|
|
114
|
+
const { content, instanceId } = getSubOpts(this);
|
|
115
|
+
await cmdSendMessage(getZkHosts(this), instanceId, content);
|
|
115
116
|
}
|
|
116
117
|
catch (e) {
|
|
117
118
|
output({ error: String(e) }, true);
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EACL,WAAW,EACX,WAAW,EACX,YAAY,EACZ,eAAe,EACf,WAAW,EACX,cAAc,EACd,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,QAAQ,EACR,YAAY,EACZ,WAAW,EACX,YAAY,GACb,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAE3C,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAE1C,MAAM,SAAS,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC1D,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,cAAc,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;AAErF,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO;KACJ,IAAI,CAAC,qBAAqB,CAAC;KAC3B,WAAW,CAAC,mDAAmD,CAAC;KAChE,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC;KACpB,MAAM,CACL,yBAAyB,EACzB,6CAA6C,EAC7C,gBAAgB,CACjB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { ZkClient } from "../zk/client.js";
|
|
2
|
+
import { TaskQueue } from "../modules/task-queue.js";
|
|
3
|
+
import { MessageRouter } from "../modules/message-router.js";
|
|
4
|
+
import { LeaderEventBus } from "./event-bus.js";
|
|
5
|
+
import type { ClaudeRunner } from "../executor/runner.js";
|
|
6
|
+
import { type Message } from "../models/schemas.js";
|
|
7
|
+
export declare class ChainRouter {
|
|
8
|
+
private zk;
|
|
9
|
+
private taskQueue;
|
|
10
|
+
private messageRouter;
|
|
11
|
+
private eventBus;
|
|
12
|
+
private leaderInstanceId;
|
|
13
|
+
private leaderName;
|
|
14
|
+
private runner;
|
|
15
|
+
private logger;
|
|
16
|
+
constructor(zk: ZkClient, taskQueue: TaskQueue, messageRouter: MessageRouter, eventBus: LeaderEventBus, leaderInstanceId: string, leaderName: string, runner: ClaudeRunner);
|
|
17
|
+
route(msg: Message): Promise<void>;
|
|
18
|
+
private handleRequirement;
|
|
19
|
+
private handleTaskDefinitions;
|
|
20
|
+
private handleCompletionReport;
|
|
21
|
+
private findWorkerByRole;
|
|
22
|
+
}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
import { Logger } from "../utils/logger.js";
|
|
3
|
+
import { createMessage, ChainDefSchema, EvalDecisionSchema, } from "../models/schemas.js";
|
|
4
|
+
const NEXT_LINKS = {
|
|
5
|
+
plan: "build",
|
|
6
|
+
build: "verify",
|
|
7
|
+
verify: "review",
|
|
8
|
+
review: "accept",
|
|
9
|
+
accept: null,
|
|
10
|
+
};
|
|
11
|
+
export class ChainRouter {
|
|
12
|
+
zk;
|
|
13
|
+
taskQueue;
|
|
14
|
+
messageRouter;
|
|
15
|
+
eventBus;
|
|
16
|
+
leaderInstanceId;
|
|
17
|
+
leaderName;
|
|
18
|
+
runner;
|
|
19
|
+
logger = new Logger("ChainRouter");
|
|
20
|
+
constructor(zk, taskQueue, messageRouter, eventBus, leaderInstanceId, leaderName, runner) {
|
|
21
|
+
this.zk = zk;
|
|
22
|
+
this.taskQueue = taskQueue;
|
|
23
|
+
this.messageRouter = messageRouter;
|
|
24
|
+
this.eventBus = eventBus;
|
|
25
|
+
this.leaderInstanceId = leaderInstanceId;
|
|
26
|
+
this.leaderName = leaderName;
|
|
27
|
+
this.runner = runner;
|
|
28
|
+
}
|
|
29
|
+
async route(msg) {
|
|
30
|
+
const link = msg.link;
|
|
31
|
+
if (Logger.isDebug()) {
|
|
32
|
+
this.eventBus.emit({ type: "debug_info", message: `Routing msg ${msg.id}: link=${link ?? "none"}, from=${msg.from_name}` });
|
|
33
|
+
}
|
|
34
|
+
if (!link) {
|
|
35
|
+
return this.handleRequirement(msg);
|
|
36
|
+
}
|
|
37
|
+
if (link === "task_defs") {
|
|
38
|
+
return this.handleTaskDefinitions(msg);
|
|
39
|
+
}
|
|
40
|
+
return this.handleCompletionReport(msg);
|
|
41
|
+
}
|
|
42
|
+
async handleRequirement(msg) {
|
|
43
|
+
const planner = await this.findWorkerByRole("planner");
|
|
44
|
+
if (!planner) {
|
|
45
|
+
this.logger.error("No planner worker available. Requirement not processed.");
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const fwd = createMessage({
|
|
49
|
+
from_instance: this.leaderInstanceId,
|
|
50
|
+
from_name: this.leaderName,
|
|
51
|
+
from_role: "leader",
|
|
52
|
+
to_instance: planner.id,
|
|
53
|
+
content: msg.content,
|
|
54
|
+
link: "decompose",
|
|
55
|
+
task_description: msg.content,
|
|
56
|
+
});
|
|
57
|
+
await this.zk.createMessage(planner.id, fwd);
|
|
58
|
+
this.logger.info(`Forwarded requirement to planner ${planner.name} (${planner.id.slice(0, 8)})`);
|
|
59
|
+
if (Logger.isDebug()) {
|
|
60
|
+
this.eventBus.emit({ type: "debug_info", message: `Requirement "${msg.content.slice(0, 80)}" → planner ${planner.name}` });
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
async handleTaskDefinitions(msg) {
|
|
64
|
+
let chainDef;
|
|
65
|
+
try {
|
|
66
|
+
chainDef = ChainDefSchema.parse(JSON.parse(msg.content));
|
|
67
|
+
}
|
|
68
|
+
catch (err) {
|
|
69
|
+
this.logger.error("Failed to parse task definitions", err);
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
const taskLinks = [
|
|
73
|
+
{ link: "plan", def: chainDef.tasks.plan },
|
|
74
|
+
{ link: "build", def: chainDef.tasks.build },
|
|
75
|
+
{ link: "verify", def: chainDef.tasks.verify },
|
|
76
|
+
{ link: "review", def: chainDef.tasks.review },
|
|
77
|
+
{ link: "accept", def: chainDef.tasks.accept },
|
|
78
|
+
];
|
|
79
|
+
for (const { link, def } of taskLinks) {
|
|
80
|
+
if (!def)
|
|
81
|
+
continue;
|
|
82
|
+
const task = await this.taskQueue.push(def.title, def.description, def.priority, this.leaderInstanceId, undefined, this.leaderName, undefined, link, chainDef.chain_id);
|
|
83
|
+
const docPath = this.runner.taskDocPath(task.id);
|
|
84
|
+
await fs.promises.writeFile(docPath, `# ${def.title}\n\n` +
|
|
85
|
+
`**Link**: ${link}\n` +
|
|
86
|
+
`**Chain**: ${chainDef.chain_id}\n` +
|
|
87
|
+
`**Priority**: ${def.priority}\n\n` +
|
|
88
|
+
`## Description\n\n${def.description}\n\n` +
|
|
89
|
+
`## Completion Criteria\n\n${def.criteria}\n`);
|
|
90
|
+
this.eventBus.emit({
|
|
91
|
+
type: "task_created",
|
|
92
|
+
task: { ...task },
|
|
93
|
+
taskId: task.id,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
this.eventBus.emit({ type: "chain_activated", chainId: chainDef.chain_id });
|
|
97
|
+
if (Logger.isDebug()) {
|
|
98
|
+
const linkCount = taskLinks.filter(t => t.def).length;
|
|
99
|
+
this.eventBus.emit({ type: "debug_info", message: `Chain ${chainDef.chain_id}: ${linkCount} tasks created` });
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
async handleCompletionReport(msg) {
|
|
103
|
+
let decision;
|
|
104
|
+
let parsed = true;
|
|
105
|
+
try {
|
|
106
|
+
decision = EvalDecisionSchema.parse(JSON.parse(msg.content));
|
|
107
|
+
}
|
|
108
|
+
catch {
|
|
109
|
+
parsed = false;
|
|
110
|
+
const currentLink = msg.link;
|
|
111
|
+
const nextLink = NEXT_LINKS[currentLink];
|
|
112
|
+
if (nextLink) {
|
|
113
|
+
decision = { decision: "activate_next", reason: "Auto-advance (no structured decision)", nextLink };
|
|
114
|
+
}
|
|
115
|
+
else if (nextLink === null && currentLink === "accept") {
|
|
116
|
+
decision = { decision: "close_chain", reason: "Accept link completed" };
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
decision = { decision: "activate_next", reason: "Auto-advance", nextLink: NEXT_LINKS[currentLink] ?? undefined };
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
if (Logger.isDebug()) {
|
|
123
|
+
this.eventBus.emit({ type: "debug_info", message: `EvalDecision: ${decision.decision} (${decision.reason})${parsed ? "" : " [fallback]"}` });
|
|
124
|
+
}
|
|
125
|
+
switch (decision.decision) {
|
|
126
|
+
case "activate_next": {
|
|
127
|
+
const nextLink = decision.nextLink ?? NEXT_LINKS[msg.link];
|
|
128
|
+
if (!nextLink)
|
|
129
|
+
break;
|
|
130
|
+
const task = await this.taskQueue.push(`[${msg.reply_to ?? "chain"}] ${nextLink}`, "", 1, this.leaderInstanceId, undefined, this.leaderName, undefined, nextLink, msg.chain_id ?? null);
|
|
131
|
+
this.eventBus.emit({
|
|
132
|
+
type: "task_created",
|
|
133
|
+
task: { ...task },
|
|
134
|
+
taskId: task.id,
|
|
135
|
+
});
|
|
136
|
+
break;
|
|
137
|
+
}
|
|
138
|
+
case "feedback": {
|
|
139
|
+
if (msg.from_instance && decision.feedback) {
|
|
140
|
+
await this.messageRouter.send(this.leaderInstanceId, this.leaderName, decision.feedback, msg.from_instance);
|
|
141
|
+
}
|
|
142
|
+
break;
|
|
143
|
+
}
|
|
144
|
+
case "close_chain": {
|
|
145
|
+
const chainId = msg.chain_id;
|
|
146
|
+
if (chainId) {
|
|
147
|
+
this.eventBus.emit({ type: "chain_closed", chainId });
|
|
148
|
+
}
|
|
149
|
+
break;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
async findWorkerByRole(role) {
|
|
154
|
+
const instances = await this.zk.listInstances();
|
|
155
|
+
for (const inst of instances) {
|
|
156
|
+
if (inst.role === role && inst.status === "idle") {
|
|
157
|
+
return { id: inst.id, name: inst.name };
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
return null;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=chain-router.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chain-router.js","sourceRoot":"","sources":["../../src/leader/chain-router.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type LeaderEventType = "worker_joined" | "worker_left" | "worker_status_changed" | "task_created" | "task_claimed" | "task_completed" | "task_blocked" | "task_failed" | "task_recovered" | "message_received" | "message_processed";
|
|
1
|
+
export type LeaderEventType = "worker_joined" | "worker_left" | "worker_status_changed" | "task_created" | "task_claimed" | "task_completed" | "task_blocked" | "task_failed" | "task_recovered" | "message_received" | "message_processed" | "chain_activated" | "chain_closed" | "debug_info";
|
|
2
2
|
export interface LeaderEvent {
|
|
3
3
|
type: LeaderEventType;
|
|
4
4
|
[key: string]: unknown;
|
package/dist/leader/event-bus.js
CHANGED
|
@@ -2,7 +2,7 @@ import { EventEmitter } from "node:events";
|
|
|
2
2
|
const ALL_EVENT_TYPES = [
|
|
3
3
|
"worker_joined", "worker_left", "worker_status_changed",
|
|
4
4
|
"task_created", "task_claimed", "task_completed", "task_blocked", "task_failed", "task_recovered",
|
|
5
|
-
"message_received", "message_processed",
|
|
5
|
+
"message_received", "message_processed", "chain_activated", "chain_closed", "debug_info",
|
|
6
6
|
];
|
|
7
7
|
export class LeaderEventBus {
|
|
8
8
|
emitter = new EventEmitter();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-bus.js","sourceRoot":"","sources":["../../src/leader/event-bus.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"event-bus.js","sourceRoot":"","sources":["../../src/leader/event-bus.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAuB3C,MAAM,eAAe,GAAsB;IACzC,eAAe,EAAE,aAAa,EAAE,uBAAuB;IACvD,cAAc,EAAE,cAAc,EAAE,gBAAgB,EAAE,cAAc,EAAE,aAAa,EAAE,gBAAgB;IACjG,kBAAkB,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,cAAc,EAAE,YAAY;CACzF,CAAC;AAEF,MAAM,OAAO,cAAc;IACjB,OAAO,GAAG,IAAI,YAAY,EAAE,CAAC;IAErC,KAAK,CAAC,OAAqC;QACzC,KAAK,MAAM,CAAC,IAAI,eAAe,EAAE,CAAC;YAChC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,IAAI,CAAC,KAAkB;QACrB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,EAAE,CAAC,IAAqB,EAAE,OAAqC;QAC7D,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACjC,CAAC;CACF"}
|