@adamancyzhang/claude-orchestrator 0.3.0 → 0.3.2
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 +203 -201
- package/dist/cli/commands.d.ts +6 -17
- package/dist/cli/commands.js +133 -172
- package/dist/cli/commands.js.map +1 -1
- package/dist/config.d.ts +28 -14
- package/dist/config.js +51 -20
- 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 +115 -250
- 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 +35 -13
- package/dist/leader/index.js.map +1 -1
- package/dist/leader/recovery.d.ts +2 -0
- package/dist/leader/recovery.js +37 -22
- package/dist/leader/recovery.js.map +1 -1
- package/dist/leader/state.d.ts +2 -1
- package/dist/leader/state.js +48 -2
- package/dist/leader/state.js.map +1 -1
- package/dist/leader/tui.d.ts +8 -0
- package/dist/leader/tui.js +74 -9
- package/dist/leader/tui.js.map +1 -1
- package/dist/leader/watcher.d.ts +4 -3
- package/dist/leader/watcher.js +8 -13
- package/dist/leader/watcher.js.map +1 -1
- package/dist/models/schemas.d.ts +307 -87
- package/dist/models/schemas.js +51 -43
- package/dist/models/schemas.js.map +1 -1
- package/dist/modules/message-router.d.ts +1 -3
- package/dist/modules/message-router.js +3 -26
- package/dist/modules/message-router.js.map +1 -1
- package/dist/modules/registry.js +3 -3
- package/dist/modules/registry.js.map +1 -1
- package/dist/modules/task-queue.d.ts +1 -1
- package/dist/modules/task-queue.js +28 -2
- package/dist/modules/task-queue.js.map +1 -1
- package/dist/skills/CLAUDE.md +155 -0
- package/dist/skills/claude-code-developer/SKILL.md +325 -0
- package/dist/skills/claude-orchestrator/SKILL.md +244 -0
- package/dist/skills/task-acceptance/SKILL.md +201 -0
- package/dist/skills/task-execution/SKILL.md +142 -0
- package/dist/skills/task-planning/SKILL.md +188 -0
- package/dist/skills/task-review/SKILL.md +220 -0
- package/dist/skills/task-traceability/SKILL.md +154 -0
- package/dist/skills/task-verification/SKILL.md +194 -0
- package/dist/templates/worker-accept.md +46 -0
- package/dist/templates/worker-build.md +45 -0
- package/dist/templates/worker-decompose.md +67 -0
- package/dist/templates/worker-evaluate.md +41 -0
- package/dist/templates/worker-plan.md +43 -0
- package/dist/templates/worker-review.md +46 -0
- package/dist/templates/worker-verify.md +47 -0
- package/dist/utils/exec.d.ts +5 -0
- package/dist/utils/exec.js +27 -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 +13 -4
- package/dist/worker/watcher.js +108 -24
- package/dist/worker/watcher.js.map +1 -1
- package/dist/zk/client.d.ts +0 -5
- package/dist/zk/client.js +0 -27
- package/dist/zk/client.js.map +1 -1
- package/dist/zk/paths.d.ts +8 -10
- package/dist/zk/paths.js +1 -6
- package/dist/zk/paths.js.map +1 -1
- package/dist/zk/watcher.d.ts +0 -2
- package/dist/zk/watcher.js +0 -3
- package/dist/zk/watcher.js.map +1 -1
- package/package.json +2 -2
- package/dist/modules/context-store.d.ts +0 -10
- package/dist/modules/context-store.js +0 -25
- package/dist/modules/context-store.js.map +0 -1
- package/dist/templates/leader.md +0 -10
- package/dist/templates/worker.md +0 -8
|
@@ -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"}
|
package/dist/leader/index.d.ts
CHANGED
package/dist/leader/index.js
CHANGED
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
import * as os from "node:os";
|
|
2
|
-
import * as path from "node:path";
|
|
3
|
-
import * as fs from "node:fs";
|
|
4
2
|
import { ZkClient, isNodeExists } from "../zk/client.js";
|
|
5
3
|
import { InstanceRegistry } from "../modules/registry.js";
|
|
6
4
|
import { LeaderEventBus } from "./event-bus.js";
|
|
@@ -9,16 +7,19 @@ import { WorkerMonitor } from "./monitor.js";
|
|
|
9
7
|
import { TaskOrchestrator } from "./orchestrator.js";
|
|
10
8
|
import { TaskRecovery } from "./recovery.js";
|
|
11
9
|
import { LeaderWatcher } from "./watcher.js";
|
|
12
|
-
import {
|
|
10
|
+
import { ChainRouter } from "./chain-router.js";
|
|
11
|
+
import { TaskQueue } from "../modules/task-queue.js";
|
|
12
|
+
import { MessageRouter } from "../modules/message-router.js";
|
|
13
|
+
import { ClaudeRunner } from "../executor/runner.js";
|
|
14
|
+
import { loadInstanceConfig, saveInstanceId } from "../config.js";
|
|
15
|
+
import { Logger } from "../utils/logger.js";
|
|
13
16
|
import { LeaderTui } from "./tui.js";
|
|
14
17
|
export async function startLeader(config) {
|
|
18
|
+
const logger = new Logger("Leader");
|
|
15
19
|
const zk = new ZkClient(config.zkHosts);
|
|
16
20
|
await zk.connect();
|
|
17
21
|
const instanceConfig = loadInstanceConfig();
|
|
18
|
-
const globalConfig = loadGlobalConfig();
|
|
19
22
|
const leaderName = config.name || instanceConfig.name || "Leader";
|
|
20
|
-
const command = config.command || globalConfig.command || "claude --dangerously-skip-permissions -v";
|
|
21
|
-
const cacheDir = config.cacheDir || globalConfig.cache_dir || "~/.claude-orchestrator/sessions";
|
|
22
23
|
// Create /leader EPHEMERAL node
|
|
23
24
|
const leaderId = crypto.randomUUID().replace(/-/g, "");
|
|
24
25
|
try {
|
|
@@ -34,7 +35,7 @@ export async function startLeader(config) {
|
|
|
34
35
|
}
|
|
35
36
|
catch (err) {
|
|
36
37
|
if (isNodeExists(err)) {
|
|
37
|
-
|
|
38
|
+
logger.error("Another leader is already running.");
|
|
38
39
|
process.exit(1);
|
|
39
40
|
}
|
|
40
41
|
throw err;
|
|
@@ -43,19 +44,22 @@ export async function startLeader(config) {
|
|
|
43
44
|
const registry = new InstanceRegistry(zk);
|
|
44
45
|
const instance = await registry.register(leaderName, "leader", leaderId);
|
|
45
46
|
saveInstanceId(instance.id);
|
|
46
|
-
// Initialize
|
|
47
|
-
const
|
|
48
|
-
|
|
49
|
-
await fs.promises.mkdir(myCacheDir, { recursive: true });
|
|
47
|
+
// Initialize cache runner for path management (leader doesn't call claude-cli)
|
|
48
|
+
const cacheRunner = new ClaudeRunner("", // command unused by leader
|
|
49
|
+
"~/.claude-orchestrator/sessions", instance.id, process.cwd());
|
|
50
50
|
// Initialize EventBus + State
|
|
51
51
|
const eventBus = new LeaderEventBus();
|
|
52
52
|
const state = new LeaderState();
|
|
53
53
|
state.leaderName = leaderName;
|
|
54
54
|
state.leaderInstanceId = instance.id;
|
|
55
|
-
state.cacheDir =
|
|
55
|
+
state.cacheDir = "~/.claude-orchestrator/sessions";
|
|
56
56
|
eventBus.onAll((event) => state.apply(event));
|
|
57
|
+
// Initialize TaskQueue, MessageRouter, and ChainRouter
|
|
58
|
+
const taskQueue = new TaskQueue(zk);
|
|
59
|
+
const messageRouter = new MessageRouter(zk);
|
|
60
|
+
const chainRouter = new ChainRouter(zk, taskQueue, messageRouter, eventBus, instance.id, leaderName, cacheRunner);
|
|
57
61
|
// Start subsystems
|
|
58
|
-
const leaderWatcher = new LeaderWatcher(zk, eventBus, instance.id,
|
|
62
|
+
const leaderWatcher = new LeaderWatcher(zk, eventBus, instance.id, chainRouter);
|
|
59
63
|
await leaderWatcher.start();
|
|
60
64
|
const monitor = new WorkerMonitor(zk, eventBus);
|
|
61
65
|
await monitor.start();
|
|
@@ -63,10 +67,28 @@ export async function startLeader(config) {
|
|
|
63
67
|
await orchestrator.start();
|
|
64
68
|
const recovery = new TaskRecovery(zk, eventBus);
|
|
65
69
|
recovery.start();
|
|
70
|
+
await recovery.scanOrphans();
|
|
66
71
|
// Initialize TUI
|
|
67
72
|
const tui = new LeaderTui();
|
|
68
73
|
eventBus.onAll(() => tui.render(state));
|
|
69
74
|
tui.render(state);
|
|
75
|
+
// Wire TUI input to send messages to leader's own queue for processing
|
|
76
|
+
tui.onInput(async (text) => {
|
|
77
|
+
try {
|
|
78
|
+
await zk.createMessage(instance.id, {
|
|
79
|
+
type: "direct",
|
|
80
|
+
from_instance: instance.id,
|
|
81
|
+
from_name: leaderName,
|
|
82
|
+
to_instance: instance.id,
|
|
83
|
+
content: text,
|
|
84
|
+
created_at: new Date().toISOString(),
|
|
85
|
+
read: false,
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
catch (err) {
|
|
89
|
+
// Best effort — message will be lost if ZK is down
|
|
90
|
+
}
|
|
91
|
+
});
|
|
70
92
|
// Block on SIGINT
|
|
71
93
|
await new Promise((resolve) => {
|
|
72
94
|
const cleanup = () => {
|
package/dist/leader/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/leader/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAC9B,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/leader/index.ts"],"names":[],"mappings":"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"}
|
package/dist/leader/recovery.js
CHANGED
|
@@ -11,6 +11,42 @@ export class TaskRecovery {
|
|
|
11
11
|
this.recoverOrphanedTasks(event.instanceId);
|
|
12
12
|
});
|
|
13
13
|
}
|
|
14
|
+
async scanOrphans() {
|
|
15
|
+
if (!this.zk.connected)
|
|
16
|
+
return;
|
|
17
|
+
const instances = await this.zk.listInstances();
|
|
18
|
+
const onlineIds = new Set(instances.map((i) => i.id));
|
|
19
|
+
const claimed = await this.zk.listClaimedTasks();
|
|
20
|
+
for (const [insId, taskId, data] of claimed) {
|
|
21
|
+
if (!onlineIds.has(insId)) {
|
|
22
|
+
await this.recoverOrphan(insId, taskId, data);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
async recoverOrphan(workerId, taskId, data) {
|
|
27
|
+
const retryCount = (data.retry_count ?? 0) + 1;
|
|
28
|
+
if (retryCount > MAX_RETRIES) {
|
|
29
|
+
await this.zk.saveCompletedTask(taskId, {
|
|
30
|
+
...data,
|
|
31
|
+
status: "failed",
|
|
32
|
+
completed_at: new Date().toISOString(),
|
|
33
|
+
retry_count: retryCount,
|
|
34
|
+
fail_reason: `Max retries (${MAX_RETRIES}) exceeded after worker disconnect`,
|
|
35
|
+
});
|
|
36
|
+
await this.zk.deleteClaimedTask(workerId, taskId);
|
|
37
|
+
this.eventBus.emit({ type: "task_failed", taskId, reason: "Max retries exceeded" });
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
const taskData = { ...data };
|
|
41
|
+
taskData.retry_count = retryCount;
|
|
42
|
+
taskData.status = "pending";
|
|
43
|
+
delete taskData.claimed_by;
|
|
44
|
+
delete taskData.claimed_at;
|
|
45
|
+
const newTaskId = await this.zk.createPendingTask(taskData);
|
|
46
|
+
await this.zk.deleteClaimedTask(workerId, taskId);
|
|
47
|
+
this.eventBus.emit({ type: "task_recovered", taskId, newTaskId, retryCount });
|
|
48
|
+
}
|
|
49
|
+
}
|
|
14
50
|
async recoverOrphanedTasks(workerId) {
|
|
15
51
|
if (!this.zk.connected)
|
|
16
52
|
return;
|
|
@@ -18,28 +54,7 @@ export class TaskRecovery {
|
|
|
18
54
|
for (const [insId, taskId, data] of claimed) {
|
|
19
55
|
if (insId !== workerId)
|
|
20
56
|
continue;
|
|
21
|
-
|
|
22
|
-
if (retryCount > MAX_RETRIES) {
|
|
23
|
-
await this.zk.saveCompletedTask(taskId, {
|
|
24
|
-
...data,
|
|
25
|
-
status: "failed",
|
|
26
|
-
completed_at: new Date().toISOString(),
|
|
27
|
-
retry_count: retryCount,
|
|
28
|
-
fail_reason: `Max retries (${MAX_RETRIES}) exceeded after worker disconnect`,
|
|
29
|
-
});
|
|
30
|
-
await this.zk.deleteClaimedTask(insId, taskId);
|
|
31
|
-
this.eventBus.emit({ type: "task_failed", taskId, reason: "Max retries exceeded" });
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
const taskData = { ...data };
|
|
35
|
-
taskData.retry_count = retryCount;
|
|
36
|
-
taskData.status = "pending";
|
|
37
|
-
delete taskData.claimed_by;
|
|
38
|
-
delete taskData.claimed_at;
|
|
39
|
-
const newTaskId = await this.zk.createPendingTask(taskData);
|
|
40
|
-
await this.zk.deleteClaimedTask(insId, taskId);
|
|
41
|
-
this.eventBus.emit({ type: "task_recovered", taskId, newTaskId, retryCount });
|
|
42
|
-
}
|
|
57
|
+
await this.recoverOrphan(insId, taskId, data);
|
|
43
58
|
}
|
|
44
59
|
}
|
|
45
60
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"recovery.js","sourceRoot":"","sources":["../../src/leader/recovery.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,GAAG,CAAC,CAAC;AAEtB,MAAM,OAAO,YAAY;IAEb;IACA;IAFV,YACU,EAAY,EACZ,QAAwB;QADxB,OAAE,GAAF,EAAE,CAAU;QACZ,aAAQ,GAAR,QAAQ,CAAgB;IAC/B,CAAC;IAEJ,KAAK;QACH,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE;YACxC,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,UAAoB,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;IACL,CAAC;
|
|
1
|
+
{"version":3,"file":"recovery.js","sourceRoot":"","sources":["../../src/leader/recovery.ts"],"names":[],"mappings":"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"}
|
package/dist/leader/state.d.ts
CHANGED
package/dist/leader/state.js
CHANGED
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
function taskLinkToRole(link) {
|
|
2
|
+
const map = {
|
|
3
|
+
plan: "planner",
|
|
4
|
+
build: "builder",
|
|
5
|
+
verify: "verifier",
|
|
6
|
+
review: "reviewer",
|
|
7
|
+
accept: "accepter",
|
|
8
|
+
};
|
|
9
|
+
return map[link] ?? link;
|
|
10
|
+
}
|
|
1
11
|
export class LeaderState {
|
|
2
12
|
workers = [];
|
|
3
13
|
pendingTasks = [];
|
|
@@ -17,7 +27,8 @@ export class LeaderState {
|
|
|
17
27
|
this.workers.push({
|
|
18
28
|
id: event.instanceId ?? inst.id,
|
|
19
29
|
name: inst.name,
|
|
20
|
-
|
|
30
|
+
presetRole: inst.role,
|
|
31
|
+
currentRole: null,
|
|
21
32
|
status: inst.status,
|
|
22
33
|
currentTaskId: inst.current_task_id ?? null,
|
|
23
34
|
});
|
|
@@ -33,6 +44,8 @@ export class LeaderState {
|
|
|
33
44
|
if (w) {
|
|
34
45
|
w.status = event.status;
|
|
35
46
|
w.currentTaskId = event.currentTaskId ?? null;
|
|
47
|
+
if (!w.currentTaskId)
|
|
48
|
+
w.currentRole = null;
|
|
36
49
|
}
|
|
37
50
|
this.events.push({ timestamp: time, message: `${event.name}: ${event.status}` });
|
|
38
51
|
break;
|
|
@@ -51,20 +64,44 @@ export class LeaderState {
|
|
|
51
64
|
this.claimedTasks.push(t);
|
|
52
65
|
this.pendingTasks = this.pendingTasks.filter(t => t.id !== event.taskId);
|
|
53
66
|
}
|
|
67
|
+
// Derive currentRole from the task's link
|
|
68
|
+
const w = this.workers.find(w => w.id === event.instanceId);
|
|
69
|
+
if (w) {
|
|
70
|
+
const taskLink = t?.link ?? event.link ?? null;
|
|
71
|
+
w.currentRole = taskLink ? taskLinkToRole(taskLink) : null;
|
|
72
|
+
w.currentTaskId = event.taskId ?? null;
|
|
73
|
+
w.status = "busy";
|
|
74
|
+
}
|
|
54
75
|
this.events.push({ timestamp: time, message: `Task ${event.taskId} claimed by ${event.instanceId}` });
|
|
55
76
|
break;
|
|
56
77
|
}
|
|
57
|
-
case "task_completed":
|
|
78
|
+
case "task_completed": {
|
|
58
79
|
this.claimedTasks = this.claimedTasks.filter(t => t.id !== event.taskId);
|
|
59
80
|
if (event.task)
|
|
60
81
|
this.completedTasks.push(event.task);
|
|
82
|
+
// Clear currentRole for the worker
|
|
83
|
+
const w = this.workers.find(w => w.id === event.instanceId);
|
|
84
|
+
if (w) {
|
|
85
|
+
w.currentRole = null;
|
|
86
|
+
w.status = "idle";
|
|
87
|
+
w.currentTaskId = null;
|
|
88
|
+
}
|
|
61
89
|
this.events.push({ timestamp: time, message: `Task ${event.taskId} completed` });
|
|
62
90
|
break;
|
|
91
|
+
}
|
|
63
92
|
case "task_blocked":
|
|
64
93
|
this.events.push({ timestamp: time, message: `Task ${event.taskId} blocked: ${event.reason}` });
|
|
65
94
|
break;
|
|
66
95
|
case "task_failed":
|
|
67
96
|
this.claimedTasks = this.claimedTasks.filter(t => t.id !== event.taskId);
|
|
97
|
+
{
|
|
98
|
+
const w = this.workers.find(w => w.id === event.instanceId);
|
|
99
|
+
if (w) {
|
|
100
|
+
w.currentRole = null;
|
|
101
|
+
w.status = "idle";
|
|
102
|
+
w.currentTaskId = null;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
68
105
|
this.events.push({ timestamp: time, message: `Task ${event.taskId} failed: ${event.reason}` });
|
|
69
106
|
break;
|
|
70
107
|
case "task_recovered":
|
|
@@ -76,6 +113,15 @@ export class LeaderState {
|
|
|
76
113
|
case "message_processed":
|
|
77
114
|
this.events.push({ timestamp: time, message: `Message ${event.msgId} processed` });
|
|
78
115
|
break;
|
|
116
|
+
case "chain_activated":
|
|
117
|
+
this.events.push({ timestamp: time, message: `Chain ${event.chainId} activated` });
|
|
118
|
+
break;
|
|
119
|
+
case "chain_closed":
|
|
120
|
+
this.events.push({ timestamp: time, message: `Chain ${event.chainId} closed` });
|
|
121
|
+
break;
|
|
122
|
+
case "debug_info":
|
|
123
|
+
this.events.push({ timestamp: time, message: `[DEBUG] ${event.message}` });
|
|
124
|
+
break;
|
|
79
125
|
}
|
|
80
126
|
// Keep event log to last 100 entries
|
|
81
127
|
if (this.events.length > 100)
|
package/dist/leader/state.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"state.js","sourceRoot":"","sources":["../../src/leader/state.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"state.js","sourceRoot":"","sources":["../../src/leader/state.ts"],"names":[],"mappings":"AAEA,SAAS,cAAc,CAAC,IAAY;IAClC,MAAM,GAAG,GAA2B;QAClC,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,SAAS;QAChB,MAAM,EAAE,UAAU;QAClB,MAAM,EAAE,UAAU;QAClB,MAAM,EAAE,UAAU;KACnB,CAAC;IACF,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC;AAC3B,CAAC;AAgBD,MAAM,OAAO,WAAW;IACtB,OAAO,GAAiB,EAAE,CAAC;IAC3B,YAAY,GAA8B,EAAE,CAAC;IAC7C,YAAY,GAA8B,EAAE,CAAC;IAC7C,cAAc,GAA8B,EAAE,CAAC;IAC/C,MAAM,GAAoB,EAAE,CAAC;IAC7B,UAAU,GAAG,EAAE,CAAC;IAChB,gBAAgB,GAAG,EAAE,CAAC;IACtB,QAAQ,GAAG,EAAE,CAAC;IAEd,KAAK,CAAC,KAAkB;QACtB,MAAM,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC,kBAAkB,EAAE,CAAC;QAC7C,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,KAAK,eAAe,CAAC,CAAC,CAAC;gBACrB,MAAM,IAAI,GAAG,KAAK,CAAC,QAAmC,CAAC;gBACvD,IAAI,CAAC,IAAI;oBAAE,OAAO;gBAClB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;oBAChB,EAAE,EAAG,KAAK,CAAC,UAAqB,IAAK,IAAI,CAAC,EAAa;oBACvD,IAAI,EAAE,IAAI,CAAC,IAAc;oBACzB,UAAU,EAAE,IAAI,CAAC,IAAc;oBAC/B,WAAW,EAAE,IAAI;oBACjB,MAAM,EAAE,IAAI,CAAC,MAAgB;oBAC7B,aAAa,EAAG,IAAI,CAAC,eAA0B,IAAI,IAAI;iBACxD,CAAC,CAAC;gBACH,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,IAAI,YAAY,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC;gBACrF,MAAM;YACR,CAAC;YACD,KAAK,aAAa;gBAChB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,UAAU,CAAC,CAAC;gBACnE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC,IAAI,OAAO,EAAE,CAAC,CAAC;gBACrE,MAAM;YACR,KAAK,uBAAuB,CAAC,CAAC,CAAC;gBAC7B,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,UAAU,CAAC,CAAC;gBAC5D,IAAI,CAAC,EAAE,CAAC;oBACN,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,MAAgB,CAAC;oBAClC,CAAC,CAAC,aAAa,GAAI,KAAK,CAAC,aAAwB,IAAI,IAAI,CAAC;oBAC1D,IAAI,CAAC,CAAC,CAAC,aAAa;wBAAE,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC;gBAC7C,CAAC;gBACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBACjF,MAAM;YACR,CAAC;YACD,KAAK,cAAc,CAAC,CAAC,CAAC;gBACpB,MAAM,IAAI,GAAG,KAAK,CAAC,IAA+B,CAAC;gBACnD,IAAI,IAAI;oBAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,iBAAiB,IAAI,EAAE,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAC/F,MAAM;YACR,CAAC;YACD,KAAK,cAAc,CAAC,CAAC,CAAC;gBACpB,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC7D,IAAI,CAAC,EAAE,CAAC;oBACN,CAAC,CAAC,MAAM,GAAG,SAAS,CAAC;oBACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC3E,CAAC;gBACD,0CAA0C;gBAC1C,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,UAAU,CAAC,CAAC;gBAC5D,IAAI,CAAC,EAAE,CAAC;oBACN,MAAM,QAAQ,GAAI,CAAC,EAAE,IAAe,IAAK,KAAK,CAAC,IAAe,IAAI,IAAI,CAAC;oBACvE,CAAC,CAAC,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAC3D,CAAC,CAAC,aAAa,GAAG,KAAK,CAAC,MAAgB,IAAI,IAAI,CAAC;oBACjD,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;gBACpB,CAAC;gBACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,KAAK,CAAC,MAAM,eAAe,KAAK,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;gBACtG,MAAM;YACR,CAAC;YACD,KAAK,gBAAgB,CAAC,CAAC,CAAC;gBACtB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,CAAC,CAAC;gBACzE,IAAI,KAAK,CAAC,IAAI;oBAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,IAA+B,CAAC,CAAC;gBAChF,mCAAmC;gBACnC,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,UAAU,CAAC,CAAC;gBAC5D,IAAI,CAAC,EAAE,CAAC;oBACN,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC;oBACrB,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;oBAClB,CAAC,CAAC,aAAa,GAAG,IAAI,CAAC;gBACzB,CAAC;gBACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,KAAK,CAAC,MAAM,YAAY,EAAE,CAAC,CAAC;gBACjF,MAAM;YACR,CAAC;YACD,KAAK,cAAc;gBACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,KAAK,CAAC,MAAM,aAAa,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAChG,MAAM;YACR,KAAK,aAAa;gBAChB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,CAAC,CAAC;gBACzE,CAAC;oBACC,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,UAAU,CAAC,CAAC;oBAC5D,IAAI,CAAC,EAAE,CAAC;wBAAC,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC;wBAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;wBAAC,CAAC,CAAC,aAAa,GAAG,IAAI,CAAC;oBAAC,CAAC;gBAC7E,CAAC;gBACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,KAAK,CAAC,MAAM,YAAY,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAC/F,MAAM;YACR,KAAK,gBAAgB;gBACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,KAAK,CAAC,MAAM,gBAAgB,KAAK,CAAC,SAAS,WAAW,KAAK,CAAC,UAAU,GAAG,EAAE,CAAC,CAAC;gBAClI,MAAM;YACR,KAAK,kBAAkB;gBACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,KAAK,CAAC,IAAI,KAAM,KAAK,CAAC,OAAkB,EAAE,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC;gBAC5H,MAAM;YACR,KAAK,mBAAmB;gBACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,KAAK,CAAC,KAAK,YAAY,EAAE,CAAC,CAAC;gBACnF,MAAM;YACR,KAAK,iBAAiB;gBACpB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,KAAK,CAAC,OAAO,YAAY,EAAE,CAAC,CAAC;gBACnF,MAAM;YACR,KAAK,cAAc;gBACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,KAAK,CAAC,OAAO,SAAS,EAAE,CAAC,CAAC;gBAChF,MAAM;YACR,KAAK,YAAY;gBACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;gBAC3E,MAAM;QACV,CAAC;QACD,qCAAqC;QACrC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,GAAG;YAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IACpD,CAAC;CACF"}
|
package/dist/leader/tui.d.ts
CHANGED
|
@@ -1,5 +1,13 @@
|
|
|
1
1
|
import { LeaderState } from "./state.js";
|
|
2
2
|
export declare class LeaderTui {
|
|
3
|
+
private inputBuffer;
|
|
4
|
+
private inputCallback;
|
|
5
|
+
private rawMode;
|
|
6
|
+
constructor();
|
|
7
|
+
onInput(cb: (text: string) => void): void;
|
|
8
|
+
private enableRawMode;
|
|
9
|
+
private disableRawMode;
|
|
10
|
+
private setupInput;
|
|
3
11
|
render(state: LeaderState): void;
|
|
4
12
|
destroy(): void;
|
|
5
13
|
}
|