agent-relay 2.2.24 → 2.3.1
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/package.json +64 -21
- package/packages/acp-bridge/package.json +2 -2
- package/packages/api-types/package.json +1 -1
- package/packages/benchmark/package.json +5 -5
- package/packages/bridge/package.json +7 -7
- package/packages/cli-tester/package.json +1 -1
- package/packages/config/package.json +2 -2
- package/packages/continuity/package.json +2 -2
- package/packages/daemon/package.json +12 -12
- package/packages/hooks/package.json +4 -4
- package/packages/mcp/package.json +5 -5
- package/packages/memory/package.json +2 -2
- package/packages/policy/package.json +2 -2
- package/packages/protocol/package.json +1 -1
- package/packages/resiliency/package.json +1 -1
- package/packages/sdk/package.json +3 -3
- package/packages/sdk-ts/README.md +65 -0
- package/packages/sdk-ts/dist/__tests__/integration.test.d.ts +2 -0
- package/packages/sdk-ts/dist/__tests__/integration.test.d.ts.map +1 -0
- package/packages/sdk-ts/dist/__tests__/integration.test.js +139 -0
- package/packages/sdk-ts/dist/__tests__/integration.test.js.map +1 -0
- package/packages/sdk-ts/dist/__tests__/quickstart.test.d.ts +2 -0
- package/packages/sdk-ts/dist/__tests__/quickstart.test.d.ts.map +1 -0
- package/packages/sdk-ts/dist/__tests__/quickstart.test.js +176 -0
- package/packages/sdk-ts/dist/__tests__/quickstart.test.js.map +1 -0
- package/packages/sdk-ts/dist/browser.d.ts +16 -0
- package/packages/sdk-ts/dist/browser.d.ts.map +1 -0
- package/packages/sdk-ts/dist/browser.js +19 -0
- package/packages/sdk-ts/dist/browser.js.map +1 -0
- package/packages/sdk-ts/dist/client.d.ts +91 -0
- package/packages/sdk-ts/dist/client.d.ts.map +1 -0
- package/packages/sdk-ts/dist/client.js +360 -0
- package/packages/sdk-ts/dist/client.js.map +1 -0
- package/packages/sdk-ts/dist/consensus-helpers.d.ts +103 -0
- package/packages/sdk-ts/dist/consensus-helpers.d.ts.map +1 -0
- package/packages/sdk-ts/dist/consensus-helpers.js +147 -0
- package/packages/sdk-ts/dist/consensus-helpers.js.map +1 -0
- package/packages/sdk-ts/dist/consensus.d.ts +72 -0
- package/packages/sdk-ts/dist/consensus.d.ts.map +1 -0
- package/packages/sdk-ts/dist/consensus.js +378 -0
- package/packages/sdk-ts/dist/consensus.js.map +1 -0
- package/packages/sdk-ts/dist/examples/demo.d.ts +2 -0
- package/packages/sdk-ts/dist/examples/demo.d.ts.map +1 -0
- package/packages/sdk-ts/dist/examples/demo.js +63 -0
- package/packages/sdk-ts/dist/examples/demo.js.map +1 -0
- package/packages/sdk-ts/dist/examples/example.d.ts +2 -0
- package/packages/sdk-ts/dist/examples/example.d.ts.map +1 -0
- package/packages/sdk-ts/dist/examples/example.js +80 -0
- package/packages/sdk-ts/dist/examples/example.js.map +1 -0
- package/packages/sdk-ts/dist/examples/quickstart.d.ts +2 -0
- package/packages/sdk-ts/dist/examples/quickstart.d.ts.map +1 -0
- package/packages/sdk-ts/dist/examples/quickstart.js +56 -0
- package/packages/sdk-ts/dist/examples/quickstart.js.map +1 -0
- package/packages/sdk-ts/dist/examples/ralph-loop.d.ts +2 -0
- package/packages/sdk-ts/dist/examples/ralph-loop.d.ts.map +1 -0
- package/packages/sdk-ts/dist/examples/ralph-loop.js +281 -0
- package/packages/sdk-ts/dist/examples/ralph-loop.js.map +1 -0
- package/packages/sdk-ts/dist/index.d.ts +9 -0
- package/packages/sdk-ts/dist/index.d.ts.map +1 -0
- package/packages/sdk-ts/dist/index.js +9 -0
- package/packages/sdk-ts/dist/index.js.map +1 -0
- package/packages/sdk-ts/dist/logs.d.ts +47 -0
- package/packages/sdk-ts/dist/logs.d.ts.map +1 -0
- package/packages/sdk-ts/dist/logs.js +137 -0
- package/packages/sdk-ts/dist/logs.js.map +1 -0
- package/packages/sdk-ts/dist/protocol.d.ts +249 -0
- package/packages/sdk-ts/dist/protocol.d.ts.map +1 -0
- package/packages/sdk-ts/dist/protocol.js +2 -0
- package/packages/sdk-ts/dist/protocol.js.map +1 -0
- package/packages/sdk-ts/dist/pty.d.ts +8 -0
- package/packages/sdk-ts/dist/pty.d.ts.map +1 -0
- package/packages/sdk-ts/dist/pty.js +14 -0
- package/packages/sdk-ts/dist/pty.js.map +1 -0
- package/packages/sdk-ts/dist/relay.d.ts +118 -0
- package/packages/sdk-ts/dist/relay.d.ts.map +1 -0
- package/packages/sdk-ts/dist/relay.js +355 -0
- package/packages/sdk-ts/dist/relay.js.map +1 -0
- package/packages/sdk-ts/dist/relaycast.d.ts +57 -0
- package/packages/sdk-ts/dist/relaycast.d.ts.map +1 -0
- package/packages/sdk-ts/dist/relaycast.js +110 -0
- package/packages/sdk-ts/dist/relaycast.js.map +1 -0
- package/packages/sdk-ts/dist/shadow.d.ts +100 -0
- package/packages/sdk-ts/dist/shadow.d.ts.map +1 -0
- package/packages/sdk-ts/dist/shadow.js +174 -0
- package/packages/sdk-ts/dist/shadow.js.map +1 -0
- package/packages/sdk-ts/package.json +75 -0
- package/packages/sdk-ts/scripts/bundle-agent-relay.mjs +53 -0
- package/packages/sdk-ts/src/__tests__/integration.test.ts +170 -0
- package/packages/sdk-ts/src/__tests__/quickstart.test.ts +198 -0
- package/packages/sdk-ts/src/browser.ts +57 -0
- package/packages/sdk-ts/src/client.ts +491 -0
- package/packages/sdk-ts/src/consensus-helpers.ts +253 -0
- package/packages/sdk-ts/src/consensus.ts +506 -0
- package/packages/sdk-ts/src/examples/demo.ts +88 -0
- package/packages/sdk-ts/src/examples/example.ts +91 -0
- package/packages/sdk-ts/src/examples/quickstart.ts +72 -0
- package/packages/sdk-ts/src/examples/ralph-loop.ts +352 -0
- package/packages/sdk-ts/src/examples/sample-prd.json +37 -0
- package/packages/sdk-ts/src/index.ts +8 -0
- package/packages/sdk-ts/src/logs.ts +163 -0
- package/packages/sdk-ts/src/protocol.ts +266 -0
- package/packages/sdk-ts/src/pty.ts +16 -0
- package/packages/sdk-ts/src/relay.ts +454 -0
- package/packages/sdk-ts/src/relaycast.ts +143 -0
- package/packages/sdk-ts/src/shadow.ts +230 -0
- package/packages/sdk-ts/tsconfig.json +16 -0
- package/packages/spawner/package.json +1 -1
- package/packages/state/package.json +1 -1
- package/packages/storage/package.json +2 -2
- package/packages/telemetry/package.json +1 -1
- package/packages/trajectory/package.json +2 -2
- package/packages/user-directory/package.json +2 -2
- package/packages/utils/package.json +3 -3
- package/packages/wrapper/package.json +6 -6
- package/packages/mcp/SPEC.md +0 -1922
- package/packages/mcp/STAFFING_PLAN.md +0 -294
|
@@ -0,0 +1,360 @@
|
|
|
1
|
+
import { once } from "node:events";
|
|
2
|
+
import { spawn } from "node:child_process";
|
|
3
|
+
import { createInterface } from "node:readline";
|
|
4
|
+
import fs from "node:fs";
|
|
5
|
+
import os from "node:os";
|
|
6
|
+
import path from "node:path";
|
|
7
|
+
import { fileURLToPath } from "node:url";
|
|
8
|
+
import { PROTOCOL_VERSION, } from "./protocol.js";
|
|
9
|
+
export class AgentRelayProtocolError extends Error {
|
|
10
|
+
code;
|
|
11
|
+
retryable;
|
|
12
|
+
data;
|
|
13
|
+
constructor(payload) {
|
|
14
|
+
super(payload.message);
|
|
15
|
+
this.name = "AgentRelayProtocolError";
|
|
16
|
+
this.code = payload.code;
|
|
17
|
+
this.retryable = payload.retryable;
|
|
18
|
+
this.data = payload.data;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export class AgentRelayProcessError extends Error {
|
|
22
|
+
constructor(message) {
|
|
23
|
+
super(message);
|
|
24
|
+
this.name = "AgentRelayProcessError";
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
export class AgentRelayClient {
|
|
28
|
+
options;
|
|
29
|
+
child;
|
|
30
|
+
stdoutRl;
|
|
31
|
+
stderrRl;
|
|
32
|
+
requestSeq = 0;
|
|
33
|
+
pending = new Map();
|
|
34
|
+
startingPromise;
|
|
35
|
+
eventListeners = new Set();
|
|
36
|
+
stderrListeners = new Set();
|
|
37
|
+
exitPromise;
|
|
38
|
+
constructor(options = {}) {
|
|
39
|
+
this.options = {
|
|
40
|
+
binaryPath: options.binaryPath ?? resolveDefaultBinaryPath(),
|
|
41
|
+
binaryArgs: options.binaryArgs ?? [],
|
|
42
|
+
brokerName: options.brokerName ?? "broker",
|
|
43
|
+
channels: options.channels ?? ["general"],
|
|
44
|
+
cwd: options.cwd ?? process.cwd(),
|
|
45
|
+
env: options.env ?? process.env,
|
|
46
|
+
requestTimeoutMs: options.requestTimeoutMs ?? 10_000,
|
|
47
|
+
shutdownTimeoutMs: options.shutdownTimeoutMs ?? 3_000,
|
|
48
|
+
clientName: options.clientName ?? "@agent-relay/sdk-ts",
|
|
49
|
+
clientVersion: options.clientVersion ?? "0.1.0",
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
static async start(options = {}) {
|
|
53
|
+
const client = new AgentRelayClient(options);
|
|
54
|
+
await client.start();
|
|
55
|
+
return client;
|
|
56
|
+
}
|
|
57
|
+
onEvent(listener) {
|
|
58
|
+
this.eventListeners.add(listener);
|
|
59
|
+
return () => {
|
|
60
|
+
this.eventListeners.delete(listener);
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
onBrokerStderr(listener) {
|
|
64
|
+
this.stderrListeners.add(listener);
|
|
65
|
+
return () => {
|
|
66
|
+
this.stderrListeners.delete(listener);
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
async start() {
|
|
70
|
+
if (this.child) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
if (this.startingPromise) {
|
|
74
|
+
return this.startingPromise;
|
|
75
|
+
}
|
|
76
|
+
this.startingPromise = this.startInternal();
|
|
77
|
+
try {
|
|
78
|
+
await this.startingPromise;
|
|
79
|
+
}
|
|
80
|
+
finally {
|
|
81
|
+
this.startingPromise = undefined;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
async spawnPty(input) {
|
|
85
|
+
await this.start();
|
|
86
|
+
const agent = {
|
|
87
|
+
name: input.name,
|
|
88
|
+
runtime: "pty",
|
|
89
|
+
cli: input.cli,
|
|
90
|
+
args: input.args ?? [],
|
|
91
|
+
channels: input.channels ?? [],
|
|
92
|
+
};
|
|
93
|
+
const result = await this.requestOk("spawn_agent", {
|
|
94
|
+
agent,
|
|
95
|
+
});
|
|
96
|
+
return result;
|
|
97
|
+
}
|
|
98
|
+
async spawnHeadlessClaude(input) {
|
|
99
|
+
await this.start();
|
|
100
|
+
const agent = {
|
|
101
|
+
name: input.name,
|
|
102
|
+
runtime: "headless_claude",
|
|
103
|
+
args: input.args ?? [],
|
|
104
|
+
channels: input.channels ?? [],
|
|
105
|
+
};
|
|
106
|
+
const result = await this.requestOk("spawn_agent", {
|
|
107
|
+
agent,
|
|
108
|
+
});
|
|
109
|
+
return result;
|
|
110
|
+
}
|
|
111
|
+
async release(name) {
|
|
112
|
+
await this.start();
|
|
113
|
+
return this.requestOk("release_agent", { name });
|
|
114
|
+
}
|
|
115
|
+
async sendMessage(input) {
|
|
116
|
+
await this.start();
|
|
117
|
+
try {
|
|
118
|
+
return await this.requestOk("send_message", {
|
|
119
|
+
to: input.to,
|
|
120
|
+
text: input.text,
|
|
121
|
+
from: input.from,
|
|
122
|
+
thread_id: input.threadId,
|
|
123
|
+
priority: input.priority,
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
catch (error) {
|
|
127
|
+
if (error instanceof AgentRelayProtocolError && error.code === "unsupported_operation") {
|
|
128
|
+
return { event_id: "unsupported_operation", targets: [] };
|
|
129
|
+
}
|
|
130
|
+
throw error;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
async listAgents() {
|
|
134
|
+
await this.start();
|
|
135
|
+
const result = await this.requestOk("list_agents", {});
|
|
136
|
+
return result.agents;
|
|
137
|
+
}
|
|
138
|
+
async getStatus() {
|
|
139
|
+
await this.start();
|
|
140
|
+
return this.requestOk("get_status", {});
|
|
141
|
+
}
|
|
142
|
+
async shutdown() {
|
|
143
|
+
if (!this.child) {
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
try {
|
|
147
|
+
await this.requestOk("shutdown", {});
|
|
148
|
+
}
|
|
149
|
+
catch {
|
|
150
|
+
// Continue shutdown path if broker is already unhealthy.
|
|
151
|
+
}
|
|
152
|
+
const child = this.child;
|
|
153
|
+
const wait = this.exitPromise ?? Promise.resolve();
|
|
154
|
+
const timeout = setTimeout(() => {
|
|
155
|
+
if (!child.killed) {
|
|
156
|
+
child.kill("SIGTERM");
|
|
157
|
+
}
|
|
158
|
+
}, this.options.shutdownTimeoutMs);
|
|
159
|
+
try {
|
|
160
|
+
await wait;
|
|
161
|
+
}
|
|
162
|
+
finally {
|
|
163
|
+
clearTimeout(timeout);
|
|
164
|
+
if (this.child) {
|
|
165
|
+
this.child.kill("SIGKILL");
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
async waitForExit() {
|
|
170
|
+
if (!this.child) {
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
await this.exitPromise;
|
|
174
|
+
}
|
|
175
|
+
async startInternal() {
|
|
176
|
+
const resolvedBinary = expandTilde(this.options.binaryPath);
|
|
177
|
+
if (isExplicitPath(this.options.binaryPath) && !fs.existsSync(resolvedBinary)) {
|
|
178
|
+
throw new AgentRelayProcessError(`broker binary not found: ${this.options.binaryPath}`);
|
|
179
|
+
}
|
|
180
|
+
const args = [
|
|
181
|
+
...this.options.binaryArgs,
|
|
182
|
+
"init",
|
|
183
|
+
"--name",
|
|
184
|
+
this.options.brokerName,
|
|
185
|
+
"--channels",
|
|
186
|
+
this.options.channels.join(","),
|
|
187
|
+
];
|
|
188
|
+
// Ensure the SDK bin directory (containing agent-relay + relay_send) is on
|
|
189
|
+
// PATH so spawned workers can find relay_send without any user setup.
|
|
190
|
+
const env = { ...this.options.env };
|
|
191
|
+
if (isExplicitPath(this.options.binaryPath)) {
|
|
192
|
+
const binDir = path.dirname(path.resolve(resolvedBinary));
|
|
193
|
+
const currentPath = env.PATH ?? env.Path ?? "";
|
|
194
|
+
if (!currentPath.split(path.delimiter).includes(binDir)) {
|
|
195
|
+
env.PATH = `${binDir}${path.delimiter}${currentPath}`;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
const child = spawn(resolvedBinary, args, {
|
|
199
|
+
cwd: this.options.cwd,
|
|
200
|
+
env,
|
|
201
|
+
stdio: "pipe",
|
|
202
|
+
});
|
|
203
|
+
this.child = child;
|
|
204
|
+
this.stdoutRl = createInterface({ input: child.stdout, crlfDelay: Infinity });
|
|
205
|
+
this.stderrRl = createInterface({ input: child.stderr, crlfDelay: Infinity });
|
|
206
|
+
this.stdoutRl.on("line", (line) => {
|
|
207
|
+
this.handleStdoutLine(line);
|
|
208
|
+
});
|
|
209
|
+
this.stderrRl.on("line", (line) => {
|
|
210
|
+
for (const listener of this.stderrListeners) {
|
|
211
|
+
listener(line);
|
|
212
|
+
}
|
|
213
|
+
});
|
|
214
|
+
this.exitPromise = new Promise((resolve) => {
|
|
215
|
+
child.once("exit", (code, signal) => {
|
|
216
|
+
const error = new AgentRelayProcessError(`broker exited (code=${code ?? "null"}, signal=${signal ?? "null"})`);
|
|
217
|
+
this.failAllPending(error);
|
|
218
|
+
this.disposeProcessHandles();
|
|
219
|
+
resolve();
|
|
220
|
+
});
|
|
221
|
+
child.once("error", (error) => {
|
|
222
|
+
this.failAllPending(error);
|
|
223
|
+
this.disposeProcessHandles();
|
|
224
|
+
resolve();
|
|
225
|
+
});
|
|
226
|
+
});
|
|
227
|
+
await this.requestHello();
|
|
228
|
+
}
|
|
229
|
+
disposeProcessHandles() {
|
|
230
|
+
this.stdoutRl?.close();
|
|
231
|
+
this.stderrRl?.close();
|
|
232
|
+
this.stdoutRl = undefined;
|
|
233
|
+
this.stderrRl = undefined;
|
|
234
|
+
this.child = undefined;
|
|
235
|
+
this.exitPromise = undefined;
|
|
236
|
+
}
|
|
237
|
+
failAllPending(error) {
|
|
238
|
+
for (const pending of this.pending.values()) {
|
|
239
|
+
clearTimeout(pending.timeout);
|
|
240
|
+
pending.reject(error);
|
|
241
|
+
}
|
|
242
|
+
this.pending.clear();
|
|
243
|
+
}
|
|
244
|
+
handleStdoutLine(line) {
|
|
245
|
+
let parsed;
|
|
246
|
+
try {
|
|
247
|
+
parsed = JSON.parse(line);
|
|
248
|
+
}
|
|
249
|
+
catch {
|
|
250
|
+
// Non-protocol output should not crash the SDK.
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
if (!parsed || typeof parsed !== "object") {
|
|
254
|
+
return;
|
|
255
|
+
}
|
|
256
|
+
if (parsed.v !== PROTOCOL_VERSION || typeof parsed.type !== "string") {
|
|
257
|
+
return;
|
|
258
|
+
}
|
|
259
|
+
const envelope = {
|
|
260
|
+
v: parsed.v,
|
|
261
|
+
type: parsed.type,
|
|
262
|
+
request_id: parsed.request_id,
|
|
263
|
+
payload: parsed.payload,
|
|
264
|
+
};
|
|
265
|
+
if (envelope.type === "event") {
|
|
266
|
+
const payload = envelope.payload;
|
|
267
|
+
for (const listener of this.eventListeners) {
|
|
268
|
+
listener(payload);
|
|
269
|
+
}
|
|
270
|
+
return;
|
|
271
|
+
}
|
|
272
|
+
if (!envelope.request_id) {
|
|
273
|
+
return;
|
|
274
|
+
}
|
|
275
|
+
const pending = this.pending.get(envelope.request_id);
|
|
276
|
+
if (!pending) {
|
|
277
|
+
return;
|
|
278
|
+
}
|
|
279
|
+
if (envelope.type === "error") {
|
|
280
|
+
clearTimeout(pending.timeout);
|
|
281
|
+
this.pending.delete(envelope.request_id);
|
|
282
|
+
pending.reject(new AgentRelayProtocolError(envelope.payload));
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
if (envelope.type !== pending.expectedType) {
|
|
286
|
+
clearTimeout(pending.timeout);
|
|
287
|
+
this.pending.delete(envelope.request_id);
|
|
288
|
+
pending.reject(new AgentRelayProcessError(`unexpected response type '${envelope.type}' for request '${envelope.request_id}' (expected '${pending.expectedType}')`));
|
|
289
|
+
return;
|
|
290
|
+
}
|
|
291
|
+
clearTimeout(pending.timeout);
|
|
292
|
+
this.pending.delete(envelope.request_id);
|
|
293
|
+
pending.resolve(envelope);
|
|
294
|
+
}
|
|
295
|
+
async requestHello() {
|
|
296
|
+
const payload = {
|
|
297
|
+
client_name: this.options.clientName,
|
|
298
|
+
client_version: this.options.clientVersion,
|
|
299
|
+
};
|
|
300
|
+
const frame = await this.sendRequest("hello", payload, "hello_ack");
|
|
301
|
+
return frame.payload;
|
|
302
|
+
}
|
|
303
|
+
async requestOk(type, payload) {
|
|
304
|
+
const frame = await this.sendRequest(type, payload, "ok");
|
|
305
|
+
const result = frame.payload;
|
|
306
|
+
return result.result;
|
|
307
|
+
}
|
|
308
|
+
async sendRequest(type, payload, expectedType) {
|
|
309
|
+
if (!this.child) {
|
|
310
|
+
throw new AgentRelayProcessError("broker is not running");
|
|
311
|
+
}
|
|
312
|
+
const request_id = `req_${++this.requestSeq}`;
|
|
313
|
+
const message = {
|
|
314
|
+
v: PROTOCOL_VERSION,
|
|
315
|
+
type,
|
|
316
|
+
request_id,
|
|
317
|
+
payload,
|
|
318
|
+
};
|
|
319
|
+
const responsePromise = new Promise((resolve, reject) => {
|
|
320
|
+
const timeout = setTimeout(() => {
|
|
321
|
+
this.pending.delete(request_id);
|
|
322
|
+
reject(new AgentRelayProcessError(`request timed out after ${this.options.requestTimeoutMs}ms (type='${type}', request_id='${request_id}')`));
|
|
323
|
+
}, this.options.requestTimeoutMs);
|
|
324
|
+
this.pending.set(request_id, {
|
|
325
|
+
expectedType,
|
|
326
|
+
resolve,
|
|
327
|
+
reject,
|
|
328
|
+
timeout,
|
|
329
|
+
});
|
|
330
|
+
});
|
|
331
|
+
const line = `${JSON.stringify(message)}\n`;
|
|
332
|
+
if (!this.child.stdin.write(line)) {
|
|
333
|
+
await once(this.child.stdin, "drain");
|
|
334
|
+
}
|
|
335
|
+
return responsePromise;
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
function expandTilde(p) {
|
|
339
|
+
if (p === "~" || p.startsWith("~/") || p.startsWith("~\\")) {
|
|
340
|
+
const home = os.homedir();
|
|
341
|
+
return path.join(home, p.slice(2));
|
|
342
|
+
}
|
|
343
|
+
return p;
|
|
344
|
+
}
|
|
345
|
+
function isExplicitPath(binaryPath) {
|
|
346
|
+
return (binaryPath.includes("/") ||
|
|
347
|
+
binaryPath.includes("\\") ||
|
|
348
|
+
binaryPath.startsWith(".") ||
|
|
349
|
+
binaryPath.startsWith("~"));
|
|
350
|
+
}
|
|
351
|
+
function resolveDefaultBinaryPath() {
|
|
352
|
+
const exe = process.platform === "win32" ? "agent-relay.exe" : "agent-relay";
|
|
353
|
+
const moduleDir = path.dirname(fileURLToPath(import.meta.url));
|
|
354
|
+
const bundled = path.resolve(moduleDir, "..", "bin", exe);
|
|
355
|
+
if (fs.existsSync(bundled)) {
|
|
356
|
+
return bundled;
|
|
357
|
+
}
|
|
358
|
+
return "agent-relay";
|
|
359
|
+
}
|
|
360
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Consensus types and pure helper functions.
|
|
3
|
+
*
|
|
4
|
+
* This module has ZERO Node.js dependencies — safe for browser use.
|
|
5
|
+
* The ConsensusEngine class (which needs node:crypto and node:events)
|
|
6
|
+
* lives in consensus.ts.
|
|
7
|
+
*/
|
|
8
|
+
export type ConsensusType = "majority" | "supermajority" | "unanimous" | "weighted" | "quorum";
|
|
9
|
+
export type VoteValue = "approve" | "reject" | "abstain";
|
|
10
|
+
export type ProposalStatus = "pending" | "approved" | "rejected" | "expired" | "cancelled";
|
|
11
|
+
export interface AgentWeight {
|
|
12
|
+
agent: string;
|
|
13
|
+
weight: number;
|
|
14
|
+
role?: string;
|
|
15
|
+
}
|
|
16
|
+
export interface Vote {
|
|
17
|
+
agent: string;
|
|
18
|
+
value: VoteValue;
|
|
19
|
+
weight: number;
|
|
20
|
+
reason?: string;
|
|
21
|
+
timestamp: number;
|
|
22
|
+
}
|
|
23
|
+
export interface Proposal {
|
|
24
|
+
id: string;
|
|
25
|
+
title: string;
|
|
26
|
+
description: string;
|
|
27
|
+
proposer: string;
|
|
28
|
+
consensusType: ConsensusType;
|
|
29
|
+
participants: string[];
|
|
30
|
+
quorum?: number;
|
|
31
|
+
threshold?: number;
|
|
32
|
+
weights?: AgentWeight[];
|
|
33
|
+
createdAt: number;
|
|
34
|
+
expiresAt: number;
|
|
35
|
+
status: ProposalStatus;
|
|
36
|
+
votes: Vote[];
|
|
37
|
+
result?: ConsensusResult;
|
|
38
|
+
metadata?: Record<string, unknown>;
|
|
39
|
+
thread?: string;
|
|
40
|
+
}
|
|
41
|
+
export interface ConsensusResult {
|
|
42
|
+
decision: "approved" | "rejected" | "no_consensus";
|
|
43
|
+
approveWeight: number;
|
|
44
|
+
rejectWeight: number;
|
|
45
|
+
abstainWeight: number;
|
|
46
|
+
participation: number;
|
|
47
|
+
quorumMet: boolean;
|
|
48
|
+
resolvedAt: number;
|
|
49
|
+
nonVoters: string[];
|
|
50
|
+
}
|
|
51
|
+
export interface ConsensusConfig {
|
|
52
|
+
/** Default proposal timeout in ms (default: 5 min) */
|
|
53
|
+
defaultTimeoutMs: number;
|
|
54
|
+
defaultConsensusType: ConsensusType;
|
|
55
|
+
/** Supermajority threshold (0–1, default 0.67) */
|
|
56
|
+
defaultThreshold: number;
|
|
57
|
+
allowVoteChange: boolean;
|
|
58
|
+
/** Auto-resolve when outcome is mathematically certain */
|
|
59
|
+
autoResolve: boolean;
|
|
60
|
+
/** Max resolved/expired/cancelled proposals to retain. Oldest are evicted
|
|
61
|
+
* when this limit is exceeded. 0 = unlimited. Default: 100. */
|
|
62
|
+
maxRetainedProposals: number;
|
|
63
|
+
}
|
|
64
|
+
export interface ConsensusEvents {
|
|
65
|
+
"proposal:created": (proposal: Proposal) => void;
|
|
66
|
+
"proposal:voted": (proposal: Proposal, vote: Vote) => void;
|
|
67
|
+
"proposal:resolved": (proposal: Proposal, result: ConsensusResult) => void;
|
|
68
|
+
"proposal:expired": (proposal: Proposal) => void;
|
|
69
|
+
"proposal:cancelled": (proposal: Proposal) => void;
|
|
70
|
+
}
|
|
71
|
+
export interface ParsedProposalCommand {
|
|
72
|
+
title: string;
|
|
73
|
+
description: string;
|
|
74
|
+
participants: string[];
|
|
75
|
+
consensusType: ConsensusType;
|
|
76
|
+
timeoutMs?: number;
|
|
77
|
+
quorum?: number;
|
|
78
|
+
threshold?: number;
|
|
79
|
+
}
|
|
80
|
+
export declare function formatProposalMessage(proposal: Proposal): string;
|
|
81
|
+
export declare function formatResultMessage(proposal: Proposal, result: ConsensusResult): string;
|
|
82
|
+
export declare function parseVoteCommand(message: string): {
|
|
83
|
+
proposalId: string;
|
|
84
|
+
value: VoteValue;
|
|
85
|
+
reason?: string;
|
|
86
|
+
} | null;
|
|
87
|
+
export declare function isConsensusCommand(message: string): boolean;
|
|
88
|
+
/**
|
|
89
|
+
* Parse a PROPOSE command from a relay message.
|
|
90
|
+
*
|
|
91
|
+
* Format:
|
|
92
|
+
* ```
|
|
93
|
+
* PROPOSE: Title of the proposal
|
|
94
|
+
* TYPE: majority|supermajority|unanimous|weighted|quorum
|
|
95
|
+
* PARTICIPANTS: Agent1, Agent2, Agent3
|
|
96
|
+
* DESCRIPTION: Detailed description
|
|
97
|
+
* TIMEOUT: 3600000 (optional, ms)
|
|
98
|
+
* QUORUM: 3 (optional)
|
|
99
|
+
* THRESHOLD: 0.67 (optional)
|
|
100
|
+
* ```
|
|
101
|
+
*/
|
|
102
|
+
export declare function parseProposalCommand(message: string): ParsedProposalCommand | null;
|
|
103
|
+
//# sourceMappingURL=consensus-helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consensus-helpers.d.ts","sourceRoot":"","sources":["../src/consensus-helpers.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,MAAM,MAAM,aAAa,GACrB,UAAU,GACV,eAAe,GACf,WAAW,GACX,UAAU,GACV,QAAQ,CAAC;AAEb,MAAM,MAAM,SAAS,GAAG,SAAS,GAAG,QAAQ,GAAG,SAAS,CAAC;AAEzD,MAAM,MAAM,cAAc,GACtB,SAAS,GACT,UAAU,GACV,UAAU,GACV,SAAS,GACT,WAAW,CAAC;AAEhB,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,IAAI;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,SAAS,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,aAAa,CAAC;IAC7B,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,WAAW,EAAE,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,cAAc,CAAC;IACvB,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,MAAM,CAAC,EAAE,eAAe,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,eAAe;IAC9B,QAAQ,EAAE,UAAU,GAAG,UAAU,GAAG,cAAc,CAAC;IACnD,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,EAAE,CAAC;CACrB;AAED,MAAM,WAAW,eAAe;IAC9B,sDAAsD;IACtD,gBAAgB,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,aAAa,CAAC;IACpC,kDAAkD;IAClD,gBAAgB,EAAE,MAAM,CAAC;IACzB,eAAe,EAAE,OAAO,CAAC;IACzB,0DAA0D;IAC1D,WAAW,EAAE,OAAO,CAAC;IACrB;oEACgE;IAChE,oBAAoB,EAAE,MAAM,CAAC;CAC9B;AAED,MAAM,WAAW,eAAe;IAC9B,kBAAkB,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,IAAI,CAAC;IACjD,gBAAgB,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IAC3D,mBAAmB,EAAE,CACnB,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,eAAe,KACpB,IAAI,CAAC;IACV,kBAAkB,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,IAAI,CAAC;IACjD,oBAAoB,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,IAAI,CAAC;CACpD;AAED,MAAM,WAAW,qBAAqB;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,aAAa,EAAE,aAAa,CAAC;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAID,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM,CAchE;AAED,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,eAAe,GACtB,MAAM,CAYR;AAED,wBAAgB,gBAAgB,CAC9B,OAAO,EAAE,MAAM,GACd;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,SAAS,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,IAAI,CAgBlE;AAED,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAG3D;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,MAAM,GACd,qBAAqB,GAAG,IAAI,CAuE9B"}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Consensus types and pure helper functions.
|
|
3
|
+
*
|
|
4
|
+
* This module has ZERO Node.js dependencies — safe for browser use.
|
|
5
|
+
* The ConsensusEngine class (which needs node:crypto and node:events)
|
|
6
|
+
* lives in consensus.ts.
|
|
7
|
+
*/
|
|
8
|
+
// ── Pure helper functions (no Node.js deps) ──────────────────────────────────
|
|
9
|
+
export function formatProposalMessage(proposal) {
|
|
10
|
+
return [
|
|
11
|
+
`PROPOSAL: ${proposal.title}`,
|
|
12
|
+
`ID: ${proposal.id}`,
|
|
13
|
+
`From: ${proposal.proposer}`,
|
|
14
|
+
`Type: ${proposal.consensusType}`,
|
|
15
|
+
`Expires: ${new Date(proposal.expiresAt).toISOString()}`,
|
|
16
|
+
"",
|
|
17
|
+
proposal.description,
|
|
18
|
+
"",
|
|
19
|
+
`Participants: ${proposal.participants.join(", ")}`,
|
|
20
|
+
"",
|
|
21
|
+
"Reply with: VOTE <proposal-id> <approve|reject|abstain> [reason]",
|
|
22
|
+
].join("\n");
|
|
23
|
+
}
|
|
24
|
+
export function formatResultMessage(proposal, result) {
|
|
25
|
+
const lines = [
|
|
26
|
+
`CONSENSUS RESULT: ${proposal.title}`,
|
|
27
|
+
`Decision: ${result.decision.toUpperCase()}`,
|
|
28
|
+
`Participation: ${(result.participation * 100).toFixed(1)}%`,
|
|
29
|
+
"",
|
|
30
|
+
`Approve: ${result.approveWeight} | Reject: ${result.rejectWeight} | Abstain: ${result.abstainWeight}`,
|
|
31
|
+
];
|
|
32
|
+
if (result.nonVoters.length > 0) {
|
|
33
|
+
lines.push(`Non-voters: ${result.nonVoters.join(", ")}`);
|
|
34
|
+
}
|
|
35
|
+
return lines.join("\n");
|
|
36
|
+
}
|
|
37
|
+
export function parseVoteCommand(message) {
|
|
38
|
+
const trimmed = message.trim();
|
|
39
|
+
if (!trimmed.toUpperCase().startsWith("VOTE "))
|
|
40
|
+
return null;
|
|
41
|
+
// Split into at most 4 parts: "VOTE", proposalId, value, reason...
|
|
42
|
+
const parts = trimmed.split(/\s+/);
|
|
43
|
+
if (parts.length < 3)
|
|
44
|
+
return null;
|
|
45
|
+
const proposalId = parts[1];
|
|
46
|
+
const rawValue = parts[2].toLowerCase();
|
|
47
|
+
if (rawValue !== "approve" && rawValue !== "reject" && rawValue !== "abstain") {
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
const reason = parts.length > 3 ? parts.slice(3).join(" ") : undefined;
|
|
51
|
+
return { proposalId, value: rawValue, reason };
|
|
52
|
+
}
|
|
53
|
+
export function isConsensusCommand(message) {
|
|
54
|
+
const trimmed = message.trim();
|
|
55
|
+
return trimmed.startsWith("PROPOSE:") || trimmed.toUpperCase().startsWith("VOTE ");
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Parse a PROPOSE command from a relay message.
|
|
59
|
+
*
|
|
60
|
+
* Format:
|
|
61
|
+
* ```
|
|
62
|
+
* PROPOSE: Title of the proposal
|
|
63
|
+
* TYPE: majority|supermajority|unanimous|weighted|quorum
|
|
64
|
+
* PARTICIPANTS: Agent1, Agent2, Agent3
|
|
65
|
+
* DESCRIPTION: Detailed description
|
|
66
|
+
* TIMEOUT: 3600000 (optional, ms)
|
|
67
|
+
* QUORUM: 3 (optional)
|
|
68
|
+
* THRESHOLD: 0.67 (optional)
|
|
69
|
+
* ```
|
|
70
|
+
*/
|
|
71
|
+
export function parseProposalCommand(message) {
|
|
72
|
+
if (!message.trim().startsWith("PROPOSE:"))
|
|
73
|
+
return null;
|
|
74
|
+
const lines = message.split("\n").map((l) => l.trim());
|
|
75
|
+
let title;
|
|
76
|
+
let description;
|
|
77
|
+
let participants;
|
|
78
|
+
let consensusType = "majority";
|
|
79
|
+
let timeoutMs;
|
|
80
|
+
let quorum;
|
|
81
|
+
let threshold;
|
|
82
|
+
let inDescription = false;
|
|
83
|
+
const descriptionLines = [];
|
|
84
|
+
for (const line of lines) {
|
|
85
|
+
if (line.startsWith("PROPOSE:")) {
|
|
86
|
+
title = line.substring("PROPOSE:".length).trim();
|
|
87
|
+
inDescription = false;
|
|
88
|
+
}
|
|
89
|
+
else if (line.startsWith("TYPE:")) {
|
|
90
|
+
const type = line.substring("TYPE:".length).trim().toLowerCase();
|
|
91
|
+
if (["majority", "supermajority", "unanimous", "weighted", "quorum"].includes(type)) {
|
|
92
|
+
consensusType = type;
|
|
93
|
+
}
|
|
94
|
+
inDescription = false;
|
|
95
|
+
}
|
|
96
|
+
else if (line.startsWith("PARTICIPANTS:")) {
|
|
97
|
+
const str = line.substring("PARTICIPANTS:".length).trim();
|
|
98
|
+
participants = str
|
|
99
|
+
.split(",")
|
|
100
|
+
.map((p) => p.trim())
|
|
101
|
+
.filter((p) => p.length > 0);
|
|
102
|
+
inDescription = false;
|
|
103
|
+
}
|
|
104
|
+
else if (line.startsWith("DESCRIPTION:")) {
|
|
105
|
+
description = line.substring("DESCRIPTION:".length).trim();
|
|
106
|
+
inDescription = true;
|
|
107
|
+
}
|
|
108
|
+
else if (line.startsWith("TIMEOUT:")) {
|
|
109
|
+
const val = parseInt(line.substring("TIMEOUT:".length).trim(), 10);
|
|
110
|
+
if (!isNaN(val) && val > 0)
|
|
111
|
+
timeoutMs = val;
|
|
112
|
+
inDescription = false;
|
|
113
|
+
}
|
|
114
|
+
else if (line.startsWith("QUORUM:")) {
|
|
115
|
+
const val = parseInt(line.substring("QUORUM:".length).trim(), 10);
|
|
116
|
+
if (!isNaN(val) && val > 0)
|
|
117
|
+
quorum = val;
|
|
118
|
+
inDescription = false;
|
|
119
|
+
}
|
|
120
|
+
else if (line.startsWith("THRESHOLD:")) {
|
|
121
|
+
const val = parseFloat(line.substring("THRESHOLD:".length).trim());
|
|
122
|
+
if (!isNaN(val) && val > 0 && val <= 1)
|
|
123
|
+
threshold = val;
|
|
124
|
+
inDescription = false;
|
|
125
|
+
}
|
|
126
|
+
else if (inDescription && line.length > 0) {
|
|
127
|
+
descriptionLines.push(line);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
if (descriptionLines.length > 0 && description) {
|
|
131
|
+
description = description + "\n" + descriptionLines.join("\n");
|
|
132
|
+
}
|
|
133
|
+
if (!title || !participants || participants.length === 0)
|
|
134
|
+
return null;
|
|
135
|
+
if (!description)
|
|
136
|
+
description = title;
|
|
137
|
+
return {
|
|
138
|
+
title,
|
|
139
|
+
description,
|
|
140
|
+
participants,
|
|
141
|
+
consensusType,
|
|
142
|
+
timeoutMs,
|
|
143
|
+
quorum,
|
|
144
|
+
threshold,
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
//# sourceMappingURL=consensus-helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consensus-helpers.js","sourceRoot":"","sources":["../src/consensus-helpers.ts"],"names":[],"mappings":"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"}
|