svamp-cli 0.2.139 → 0.2.141
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/dist/{agentCommands-B6VyMPFX.mjs → agentCommands-Ccto8aSC.mjs} +20 -16
- package/dist/{auth-DYSCvgW5.mjs → auth-C1V6j2MC.mjs} +1 -1
- package/dist/cli.mjs +98 -55
- package/dist/{commands-CBIus6bj.mjs → commands-0o50QJOP.mjs} +5 -5
- package/dist/{commands-DrPyg-He.mjs → commands-CXEWlpdy.mjs} +1 -1
- package/dist/{commands-BrFcWUFe.mjs → commands-D7lgEFnK.mjs} +58 -2
- package/dist/{commands-DuoQQ-vP.mjs → commands-DGJMJPVR.mjs} +2 -2
- package/dist/{commands-BGW6PiJu.mjs → commands-DnDqrf52.mjs} +2 -2
- package/dist/{commands-Bs5NwPdw.mjs → commands-DoQptAKr.mjs} +2 -2
- package/dist/{fleet-Bz4yHVuR.mjs → fleet-DF-itBd1.mjs} +1 -1
- package/dist/{frpc-CiO9oDhe.mjs → frpc-DorJMSBi.mjs} +1 -1
- package/dist/{headlessCli-BhLtCuoL.mjs → headlessCli-BQVkijQh.mjs} +2 -2
- package/dist/index.mjs +1 -1
- package/dist/{package-BXCuchBC.mjs → package-DRJxplxz.mjs} +2 -2
- package/dist/{run-CWjRaUHV.mjs → run-CHutbJxU.mjs} +1 -1
- package/dist/{run-BuzSCEeh.mjs → run-vPl2hvCU.mjs} +79 -7
- package/dist/{serveCommands-Tpq4bwak.mjs → serveCommands-I-qoAc5K.mjs} +5 -5
- package/dist/{serveManager-6DbxSNLP.mjs → serveManager-Cd7jyXHD.mjs} +12 -5
- package/dist/{sideband--OM03wtc.mjs → sideband-Cg0Ttcuj.mjs} +1 -1
- package/package.json +2 -2
|
@@ -2,7 +2,7 @@ import { existsSync, readFileSync, mkdirSync, writeFileSync, renameSync } from '
|
|
|
2
2
|
import { join, dirname } from 'node:path';
|
|
3
3
|
import os from 'node:os';
|
|
4
4
|
import { requireNotSandboxed } from './sandboxDetect-DNTcbgWD.mjs';
|
|
5
|
-
import { m as shortId } from './run-
|
|
5
|
+
import { m as shortId } from './run-vPl2hvCU.mjs';
|
|
6
6
|
import 'os';
|
|
7
7
|
import 'fs/promises';
|
|
8
8
|
import 'fs';
|
|
@@ -96,7 +96,7 @@ async function sessionSetTitle(title) {
|
|
|
96
96
|
}
|
|
97
97
|
async function sessionSetProjectDescription(description) {
|
|
98
98
|
const dir = process.cwd();
|
|
99
|
-
const { projectName, writeProjectInfo, sanitizeDescription, projectInfoPath } = await import('./run-
|
|
99
|
+
const { projectName, writeProjectInfo, sanitizeDescription, projectInfoPath } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a1; });
|
|
100
100
|
const desc = sanitizeDescription(description, 240);
|
|
101
101
|
if (!desc) {
|
|
102
102
|
console.error("Project description is empty.");
|
|
@@ -180,7 +180,7 @@ async function sessionBroadcast(action, args) {
|
|
|
180
180
|
console.log(`Broadcast sent: ${action}`);
|
|
181
181
|
}
|
|
182
182
|
async function connectToMachineService() {
|
|
183
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
183
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
184
184
|
return connectAndGetMachine();
|
|
185
185
|
}
|
|
186
186
|
async function inboxSend(targetSessionId, opts) {
|
|
@@ -195,12 +195,9 @@ async function inboxSend(targetSessionId, opts) {
|
|
|
195
195
|
console.error("Message body is required.");
|
|
196
196
|
process.exit(1);
|
|
197
197
|
}
|
|
198
|
-
const {
|
|
198
|
+
const { connectAndResolveSession } = await import('./commands-D7lgEFnK.mjs');
|
|
199
|
+
const { server, machine, fullId } = await connectAndResolveSession(targetSessionId);
|
|
199
200
|
try {
|
|
200
|
-
const { resolveSessionId } = await import('./commands-BrFcWUFe.mjs');
|
|
201
|
-
const sessions = await machine.listSessions();
|
|
202
|
-
const match = resolveSessionId(sessions, targetSessionId);
|
|
203
|
-
const fullTargetId = match.sessionId;
|
|
204
201
|
const message = {
|
|
205
202
|
messageId: shortId(),
|
|
206
203
|
body,
|
|
@@ -208,12 +205,12 @@ async function inboxSend(targetSessionId, opts) {
|
|
|
208
205
|
read: false,
|
|
209
206
|
from: `agent:${sessionId}`,
|
|
210
207
|
fromSession: sessionId,
|
|
211
|
-
to:
|
|
208
|
+
to: fullId,
|
|
212
209
|
subject: opts?.subject,
|
|
213
210
|
urgency: opts?.urgency || "normal"
|
|
214
211
|
};
|
|
215
|
-
const result = await machine.sessionRPC(
|
|
216
|
-
console.log(`Inbox message sent to ${
|
|
212
|
+
const result = await machine.sessionRPC(fullId, "sendInboxMessage", { message });
|
|
213
|
+
console.log(`Inbox message sent to ${fullId.slice(0, 8)} (id: ${result.messageId.slice(0, 8)})`);
|
|
217
214
|
} finally {
|
|
218
215
|
await server.disconnect();
|
|
219
216
|
}
|
|
@@ -256,10 +253,11 @@ async function inboxReply(messageId, body) {
|
|
|
256
253
|
console.error("SVAMP_SESSION_ID not set. This command must be run inside a Svamp session.");
|
|
257
254
|
process.exit(1);
|
|
258
255
|
}
|
|
256
|
+
let original;
|
|
259
257
|
const { server, machine } = await connectToMachineService();
|
|
260
258
|
try {
|
|
261
259
|
const result = await machine.sessionRPC(sessionId, "getInbox", {});
|
|
262
|
-
|
|
260
|
+
original = result.messages.find((m) => m.messageId === messageId || m.messageId.startsWith(messageId));
|
|
263
261
|
if (!original) {
|
|
264
262
|
console.error(`Message ${messageId} not found in inbox.`);
|
|
265
263
|
process.exit(1);
|
|
@@ -279,6 +277,12 @@ async function inboxReply(messageId, body) {
|
|
|
279
277
|
console.error("Cannot reply: original message has no fromSession (and not a channel message).");
|
|
280
278
|
process.exit(1);
|
|
281
279
|
}
|
|
280
|
+
} finally {
|
|
281
|
+
await server.disconnect();
|
|
282
|
+
}
|
|
283
|
+
const { connectAndResolveSession } = await import('./commands-D7lgEFnK.mjs');
|
|
284
|
+
const { server: sendServer, machine: sendMachine, fullId } = await connectAndResolveSession(original.fromSession);
|
|
285
|
+
try {
|
|
282
286
|
const reply = {
|
|
283
287
|
messageId: shortId(),
|
|
284
288
|
body,
|
|
@@ -286,16 +290,16 @@ async function inboxReply(messageId, body) {
|
|
|
286
290
|
read: false,
|
|
287
291
|
from: `agent:${sessionId}`,
|
|
288
292
|
fromSession: sessionId,
|
|
289
|
-
to:
|
|
293
|
+
to: fullId,
|
|
290
294
|
subject: original.subject ? `Re: ${original.subject}` : void 0,
|
|
291
295
|
urgency: "normal",
|
|
292
296
|
replyTo: original.messageId,
|
|
293
297
|
threadId: original.threadId || original.messageId
|
|
294
298
|
};
|
|
295
|
-
const sendResult = await
|
|
296
|
-
console.log(`Reply sent to ${
|
|
299
|
+
const sendResult = await sendMachine.sessionRPC(fullId, "sendInboxMessage", { message: reply });
|
|
300
|
+
console.log(`Reply sent to ${fullId.slice(0, 8)} (id: ${sendResult.messageId.slice(0, 8)})`);
|
|
297
301
|
} finally {
|
|
298
|
-
await
|
|
302
|
+
await sendServer.disconnect();
|
|
299
303
|
}
|
|
300
304
|
}
|
|
301
305
|
async function machineNotify(message, level = "info") {
|
package/dist/cli.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { e as clearStopMarker, f as stopMarkerExists, s as startDaemon, b as stopDaemon, d as daemonStatus } from './run-
|
|
1
|
+
import { e as clearStopMarker, f as stopMarkerExists, s as startDaemon, b as stopDaemon, d as daemonStatus } from './run-vPl2hvCU.mjs';
|
|
2
2
|
import { ensureSupervisorViaServiceManager, LAUNCHD_LABEL } from './serviceManager-hlOVxkhW.mjs';
|
|
3
3
|
import 'os';
|
|
4
4
|
import 'fs/promises';
|
|
@@ -34,7 +34,7 @@ const subcommand = args[0];
|
|
|
34
34
|
let daemonSubcommand = args[1];
|
|
35
35
|
async function main() {
|
|
36
36
|
try {
|
|
37
|
-
const { getLoadedConfig } = await import('./run-
|
|
37
|
+
const { getLoadedConfig } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a8; });
|
|
38
38
|
getLoadedConfig();
|
|
39
39
|
} catch {
|
|
40
40
|
}
|
|
@@ -51,7 +51,7 @@ async function main() {
|
|
|
51
51
|
console.error(`svamp daemon restart: ${err.message || err}`);
|
|
52
52
|
process.exit(1);
|
|
53
53
|
}
|
|
54
|
-
const { restartDaemon } = await import('./run-
|
|
54
|
+
const { restartDaemon } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.aa; });
|
|
55
55
|
await restartDaemon();
|
|
56
56
|
process.exit(0);
|
|
57
57
|
}
|
|
@@ -344,7 +344,7 @@ async function main() {
|
|
|
344
344
|
console.error("svamp service: Service commands are not available in sandboxed sessions.");
|
|
345
345
|
process.exit(1);
|
|
346
346
|
}
|
|
347
|
-
const { handleServiceCommand } = await import('./commands-
|
|
347
|
+
const { handleServiceCommand } = await import('./commands-0o50QJOP.mjs');
|
|
348
348
|
await handleServiceCommand();
|
|
349
349
|
} else if (subcommand === "serve") {
|
|
350
350
|
const { isSandboxed: isSandboxedServe } = await import('./sandboxDetect-DNTcbgWD.mjs');
|
|
@@ -352,7 +352,7 @@ async function main() {
|
|
|
352
352
|
console.error("svamp serve: Serve commands are not available in sandboxed sessions.");
|
|
353
353
|
process.exit(1);
|
|
354
354
|
}
|
|
355
|
-
const { handleServeCommand } = await import('./serveCommands-
|
|
355
|
+
const { handleServeCommand } = await import('./serveCommands-I-qoAc5K.mjs');
|
|
356
356
|
await handleServeCommand();
|
|
357
357
|
process.exit(0);
|
|
358
358
|
} else if (subcommand === "process" || subcommand === "proc") {
|
|
@@ -361,7 +361,7 @@ async function main() {
|
|
|
361
361
|
console.error("svamp process: Process commands are not available in sandboxed sessions.");
|
|
362
362
|
process.exit(1);
|
|
363
363
|
}
|
|
364
|
-
const { processCommand } = await import('./commands-
|
|
364
|
+
const { processCommand } = await import('./commands-DoQptAKr.mjs');
|
|
365
365
|
let machineId;
|
|
366
366
|
const processArgs = args.slice(1);
|
|
367
367
|
const mIdx = processArgs.findIndex((a) => a === "--machine" || a === "-m");
|
|
@@ -375,14 +375,14 @@ async function main() {
|
|
|
375
375
|
}), machineId);
|
|
376
376
|
process.exit(0);
|
|
377
377
|
} else if (subcommand === "trigger" || subcommand === "triggers" || subcommand === "routine" || subcommand === "routines") {
|
|
378
|
-
const { routineCommand } = await import('./commands-
|
|
378
|
+
const { routineCommand } = await import('./commands-DnDqrf52.mjs');
|
|
379
379
|
await routineCommand(args.slice(1));
|
|
380
380
|
process.exit(0);
|
|
381
381
|
} else if (subcommand === "wise-agent" || subcommand === "wise") {
|
|
382
382
|
await handleWiseAgentCommand(args.slice(1));
|
|
383
383
|
process.exit(0);
|
|
384
384
|
} else if (subcommand === "feature" || subcommand === "crew") {
|
|
385
|
-
const { crewCommand } = await import('./commands-
|
|
385
|
+
const { crewCommand } = await import('./commands-DGJMJPVR.mjs');
|
|
386
386
|
await crewCommand(args.slice(1));
|
|
387
387
|
process.exit(0);
|
|
388
388
|
} else if (subcommand === "--help" || subcommand === "-h") {
|
|
@@ -390,7 +390,7 @@ async function main() {
|
|
|
390
390
|
} else if (!subcommand || subcommand === "start") {
|
|
391
391
|
await handleInteractiveCommand();
|
|
392
392
|
} else if (subcommand === "--version" || subcommand === "-v") {
|
|
393
|
-
const pkg = await import('./package-
|
|
393
|
+
const pkg = await import('./package-DRJxplxz.mjs').catch(() => ({ default: { version: "unknown" } }));
|
|
394
394
|
console.log(`svamp version: ${pkg.default.version}`);
|
|
395
395
|
} else {
|
|
396
396
|
console.error(`Unknown command: ${subcommand}`);
|
|
@@ -399,7 +399,7 @@ async function main() {
|
|
|
399
399
|
}
|
|
400
400
|
}
|
|
401
401
|
async function handleInteractiveCommand() {
|
|
402
|
-
const { runInteractive } = await import('./run-
|
|
402
|
+
const { runInteractive } = await import('./run-CHutbJxU.mjs');
|
|
403
403
|
const interactiveArgs = subcommand === "start" ? args.slice(1) : args;
|
|
404
404
|
let directory = process.cwd();
|
|
405
405
|
let resumeSessionId;
|
|
@@ -444,7 +444,7 @@ async function handleAgentCommand() {
|
|
|
444
444
|
return;
|
|
445
445
|
}
|
|
446
446
|
if (agentArgs[0] === "list") {
|
|
447
|
-
const { KNOWN_ACP_AGENTS, KNOWN_MCP_AGENTS: KNOWN_MCP_AGENTS2 } = await import('./run-
|
|
447
|
+
const { KNOWN_ACP_AGENTS, KNOWN_MCP_AGENTS: KNOWN_MCP_AGENTS2 } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a4; });
|
|
448
448
|
console.log("Known agents:");
|
|
449
449
|
for (const [name, config2] of Object.entries(KNOWN_ACP_AGENTS)) {
|
|
450
450
|
console.log(` ${name.padEnd(12)} ${config2.command} ${config2.args.join(" ")} (ACP)`);
|
|
@@ -456,7 +456,7 @@ async function handleAgentCommand() {
|
|
|
456
456
|
console.log('Use "svamp agent -- <command> [args]" for a custom ACP agent.');
|
|
457
457
|
return;
|
|
458
458
|
}
|
|
459
|
-
const { resolveAcpAgentConfig, KNOWN_MCP_AGENTS } = await import('./run-
|
|
459
|
+
const { resolveAcpAgentConfig, KNOWN_MCP_AGENTS } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a4; });
|
|
460
460
|
let cwd = process.cwd();
|
|
461
461
|
const filteredArgs = [];
|
|
462
462
|
for (let i = 0; i < agentArgs.length; i++) {
|
|
@@ -480,12 +480,12 @@ async function handleAgentCommand() {
|
|
|
480
480
|
console.log(`Starting ${config.agentName} agent in ${cwd}...`);
|
|
481
481
|
let backend;
|
|
482
482
|
if (KNOWN_MCP_AGENTS[config.agentName]) {
|
|
483
|
-
const { CodexMcpBackend } = await import('./run-
|
|
483
|
+
const { CodexMcpBackend } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a5; });
|
|
484
484
|
backend = new CodexMcpBackend({ cwd, log: logFn });
|
|
485
485
|
} else {
|
|
486
|
-
const { AcpBackend } = await import('./run-
|
|
487
|
-
const { GeminiTransport } = await import('./run-
|
|
488
|
-
const { DefaultTransport } = await import('./run-
|
|
486
|
+
const { AcpBackend } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a3; });
|
|
487
|
+
const { GeminiTransport } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a6; });
|
|
488
|
+
const { DefaultTransport } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a2; });
|
|
489
489
|
const transportHandler = config.agentName === "gemini" ? new GeminiTransport() : new DefaultTransport(config.agentName);
|
|
490
490
|
backend = new AcpBackend({
|
|
491
491
|
agentName: config.agentName,
|
|
@@ -612,7 +612,7 @@ async function handleSessionCommand() {
|
|
|
612
612
|
process.exit(1);
|
|
613
613
|
}
|
|
614
614
|
}
|
|
615
|
-
const { sessionList, sessionWhoami, sessionSpawn, sessionArchive, sessionResume, sessionDelete, sessionInfo, sessionMessages, sessionAttach, sessionMachines, sessionSend, sessionWait, sessionShare, sessionLoopStart, sessionLoopCancel, sessionLoopStatus, sessionChecklist, sessionInboxSend, sessionInboxList, sessionInboxRead, sessionInboxReply, sessionInboxClear } = await import('./commands-
|
|
615
|
+
const { sessionList, sessionWhoami, sessionSpawn, sessionArchive, sessionResume, sessionDelete, sessionInfo, sessionMessages, sessionAttach, sessionMachines, sessionSend, sessionWait, sessionShare, sessionLoopStart, sessionLoopCancel, sessionLoopStatus, sessionChecklist, sessionInboxSend, sessionInboxList, sessionInboxRead, sessionInboxReply, sessionInboxClear } = await import('./commands-D7lgEFnK.mjs');
|
|
616
616
|
const parseFlagStr = (flag, shortFlag) => {
|
|
617
617
|
for (let i = 1; i < sessionArgs.length; i++) {
|
|
618
618
|
if ((sessionArgs[i] === flag || shortFlag) && i + 1 < sessionArgs.length) {
|
|
@@ -680,7 +680,7 @@ async function handleSessionCommand() {
|
|
|
680
680
|
allowDomain.push(sessionArgs[++i]);
|
|
681
681
|
}
|
|
682
682
|
}
|
|
683
|
-
const { parseShareArg } = await import('./commands-
|
|
683
|
+
const { parseShareArg } = await import('./commands-D7lgEFnK.mjs');
|
|
684
684
|
const shareEntries = share.map((s) => parseShareArg(s));
|
|
685
685
|
await sessionSpawn(agent, dir, targetMachineId, {
|
|
686
686
|
message,
|
|
@@ -765,7 +765,7 @@ async function handleSessionCommand() {
|
|
|
765
765
|
console.error(" Rewinds history: rewrites the message + drops everything after it, then restarts Claude.");
|
|
766
766
|
process.exit(1);
|
|
767
767
|
}
|
|
768
|
-
const { sessionEditMessage } = await import('./commands-
|
|
768
|
+
const { sessionEditMessage } = await import('./commands-D7lgEFnK.mjs');
|
|
769
769
|
await sessionEditMessage(sessionArgs[1], sessionArgs[2], sessionArgs[3], targetMachineId);
|
|
770
770
|
} else if (sessionSubcommand === "refine") {
|
|
771
771
|
if (!sessionArgs[1] || !sessionArgs[2]) {
|
|
@@ -773,7 +773,7 @@ async function handleSessionCommand() {
|
|
|
773
773
|
console.error(" Asks the agent to revise its latest reply in place (no extra round).");
|
|
774
774
|
process.exit(1);
|
|
775
775
|
}
|
|
776
|
-
const { sessionRefineLastReply } = await import('./commands-
|
|
776
|
+
const { sessionRefineLastReply } = await import('./commands-D7lgEFnK.mjs');
|
|
777
777
|
await sessionRefineLastReply(sessionArgs[1], sessionArgs[2], targetMachineId);
|
|
778
778
|
} else if (sessionSubcommand === "undo-edit" || sessionSubcommand === "undo") {
|
|
779
779
|
if (!sessionArgs[1]) {
|
|
@@ -781,7 +781,7 @@ async function handleSessionCommand() {
|
|
|
781
781
|
console.error(" Reverts the most recent edit/refine, restoring the pre-edit history.");
|
|
782
782
|
process.exit(1);
|
|
783
783
|
}
|
|
784
|
-
const { sessionUndoEdit } = await import('./commands-
|
|
784
|
+
const { sessionUndoEdit } = await import('./commands-D7lgEFnK.mjs');
|
|
785
785
|
await sessionUndoEdit(sessionArgs[1], targetMachineId);
|
|
786
786
|
} else if (sessionSubcommand === "query") {
|
|
787
787
|
const dir = sessionArgs[1];
|
|
@@ -791,7 +791,7 @@ async function handleSessionCommand() {
|
|
|
791
791
|
console.error(" Spawns a stateless Claude session in <directory>, sends <prompt>, prints the answer, then deletes the session.");
|
|
792
792
|
process.exit(1);
|
|
793
793
|
}
|
|
794
|
-
const { sessionQuery } = await import('./commands-
|
|
794
|
+
const { sessionQuery } = await import('./commands-D7lgEFnK.mjs');
|
|
795
795
|
await sessionQuery(dir, prompt, targetMachineId, {
|
|
796
796
|
timeout: parseFlagInt("--timeout"),
|
|
797
797
|
json: hasFlag("--json"),
|
|
@@ -824,7 +824,7 @@ async function handleSessionCommand() {
|
|
|
824
824
|
console.error("Usage: svamp session approve <session-id> [request-id] [--json]");
|
|
825
825
|
process.exit(1);
|
|
826
826
|
}
|
|
827
|
-
const { sessionApprove } = await import('./commands-
|
|
827
|
+
const { sessionApprove } = await import('./commands-D7lgEFnK.mjs');
|
|
828
828
|
const approveReqId = sessionArgs[2] && !sessionArgs[2].startsWith("--") ? sessionArgs[2] : void 0;
|
|
829
829
|
await sessionApprove(sessionArgs[1], approveReqId, targetMachineId, {
|
|
830
830
|
json: hasFlag("--json")
|
|
@@ -834,7 +834,7 @@ async function handleSessionCommand() {
|
|
|
834
834
|
console.error("Usage: svamp session deny <session-id> [request-id] [--json]");
|
|
835
835
|
process.exit(1);
|
|
836
836
|
}
|
|
837
|
-
const { sessionDeny } = await import('./commands-
|
|
837
|
+
const { sessionDeny } = await import('./commands-D7lgEFnK.mjs');
|
|
838
838
|
const denyReqId = sessionArgs[2] && !sessionArgs[2].startsWith("--") ? sessionArgs[2] : void 0;
|
|
839
839
|
await sessionDeny(sessionArgs[1], denyReqId, targetMachineId, {
|
|
840
840
|
json: hasFlag("--json")
|
|
@@ -912,7 +912,7 @@ async function handleSessionCommand() {
|
|
|
912
912
|
console.error("Usage: svamp session set-title <title>");
|
|
913
913
|
process.exit(1);
|
|
914
914
|
}
|
|
915
|
-
const { sessionSetTitle } = await import('./agentCommands-
|
|
915
|
+
const { sessionSetTitle } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
916
916
|
await sessionSetTitle(title);
|
|
917
917
|
} else if (sessionSubcommand === "set-project-description" || sessionSubcommand === "set-project") {
|
|
918
918
|
const desc = sessionArgs.slice(1).filter((a) => !a.startsWith("--")).join(" ");
|
|
@@ -920,7 +920,7 @@ async function handleSessionCommand() {
|
|
|
920
920
|
console.error("Usage: svamp session set-project-description <text>");
|
|
921
921
|
process.exit(1);
|
|
922
922
|
}
|
|
923
|
-
const { sessionSetProjectDescription } = await import('./agentCommands-
|
|
923
|
+
const { sessionSetProjectDescription } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
924
924
|
await sessionSetProjectDescription(desc);
|
|
925
925
|
} else if (sessionSubcommand === "set-link") {
|
|
926
926
|
const url = sessionArgs[1];
|
|
@@ -929,7 +929,7 @@ async function handleSessionCommand() {
|
|
|
929
929
|
process.exit(1);
|
|
930
930
|
}
|
|
931
931
|
const label = sessionArgs[2] && !sessionArgs[2].startsWith("--") ? sessionArgs[2] : void 0;
|
|
932
|
-
const { sessionSetLink } = await import('./agentCommands-
|
|
932
|
+
const { sessionSetLink } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
933
933
|
await sessionSetLink(url, label);
|
|
934
934
|
} else if (sessionSubcommand === "notify") {
|
|
935
935
|
const message = sessionArgs[1];
|
|
@@ -938,7 +938,7 @@ async function handleSessionCommand() {
|
|
|
938
938
|
process.exit(1);
|
|
939
939
|
}
|
|
940
940
|
const level = parseFlagStr("--level") || "info";
|
|
941
|
-
const { sessionNotify } = await import('./agentCommands-
|
|
941
|
+
const { sessionNotify } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
942
942
|
await sessionNotify(message, level);
|
|
943
943
|
} else if (sessionSubcommand === "broadcast") {
|
|
944
944
|
const action = sessionArgs[1];
|
|
@@ -946,7 +946,7 @@ async function handleSessionCommand() {
|
|
|
946
946
|
console.error("Usage: svamp session broadcast <action> [args...]\nActions: open-canvas <url> [label], close-canvas, toast <message>");
|
|
947
947
|
process.exit(1);
|
|
948
948
|
}
|
|
949
|
-
const { sessionBroadcast } = await import('./agentCommands-
|
|
949
|
+
const { sessionBroadcast } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
950
950
|
await sessionBroadcast(action, sessionArgs.slice(2).filter((a) => !a.startsWith("--")));
|
|
951
951
|
} else if (sessionSubcommand === "inbox") {
|
|
952
952
|
const inboxSubcmd = sessionArgs[1];
|
|
@@ -957,7 +957,7 @@ async function handleSessionCommand() {
|
|
|
957
957
|
process.exit(1);
|
|
958
958
|
}
|
|
959
959
|
if (agentSessionId) {
|
|
960
|
-
const { inboxSend } = await import('./agentCommands-
|
|
960
|
+
const { inboxSend } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
961
961
|
await inboxSend(sessionArgs[2], {
|
|
962
962
|
body: sessionArgs[3],
|
|
963
963
|
subject: parseFlagStr("--subject"),
|
|
@@ -972,7 +972,7 @@ async function handleSessionCommand() {
|
|
|
972
972
|
}
|
|
973
973
|
} else if (inboxSubcmd === "list" || inboxSubcmd === "ls") {
|
|
974
974
|
if (agentSessionId && !sessionArgs[2]) {
|
|
975
|
-
const { inboxList } = await import('./agentCommands-
|
|
975
|
+
const { inboxList } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
976
976
|
await inboxList({
|
|
977
977
|
unread: hasFlag("--unread"),
|
|
978
978
|
limit: parseFlagInt("--limit"),
|
|
@@ -994,7 +994,7 @@ async function handleSessionCommand() {
|
|
|
994
994
|
process.exit(1);
|
|
995
995
|
}
|
|
996
996
|
if (agentSessionId && !sessionArgs[3]) {
|
|
997
|
-
const { inboxList } = await import('./agentCommands-
|
|
997
|
+
const { inboxList } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
998
998
|
await sessionInboxRead(agentSessionId, sessionArgs[2], targetMachineId);
|
|
999
999
|
} else if (sessionArgs[3]) {
|
|
1000
1000
|
await sessionInboxRead(sessionArgs[2], sessionArgs[3], targetMachineId);
|
|
@@ -1004,7 +1004,7 @@ async function handleSessionCommand() {
|
|
|
1004
1004
|
}
|
|
1005
1005
|
} else if (inboxSubcmd === "reply") {
|
|
1006
1006
|
if (agentSessionId && sessionArgs[2] && sessionArgs[3] && !sessionArgs[4]) {
|
|
1007
|
-
const { inboxReply } = await import('./agentCommands-
|
|
1007
|
+
const { inboxReply } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
1008
1008
|
await inboxReply(sessionArgs[2], sessionArgs[3]);
|
|
1009
1009
|
} else if (sessionArgs[2] && sessionArgs[3] && sessionArgs[4]) {
|
|
1010
1010
|
await sessionInboxReply(sessionArgs[2], sessionArgs[3], sessionArgs[4], targetMachineId);
|
|
@@ -1040,7 +1040,7 @@ async function handleMachineCommand() {
|
|
|
1040
1040
|
return;
|
|
1041
1041
|
}
|
|
1042
1042
|
if (machineSubcommand === "share") {
|
|
1043
|
-
const { machineShare } = await import('./commands-
|
|
1043
|
+
const { machineShare } = await import('./commands-D7lgEFnK.mjs');
|
|
1044
1044
|
let machineId;
|
|
1045
1045
|
const shareArgs = [];
|
|
1046
1046
|
for (let i = 1; i < machineArgs.length; i++) {
|
|
@@ -1091,14 +1091,14 @@ async function handleMachineCommand() {
|
|
|
1091
1091
|
process.exit(1);
|
|
1092
1092
|
}
|
|
1093
1093
|
if (all) {
|
|
1094
|
-
const { fleetExec } = await import('./fleet-
|
|
1094
|
+
const { fleetExec } = await import('./fleet-DF-itBd1.mjs');
|
|
1095
1095
|
await fleetExec(command, { cwd });
|
|
1096
1096
|
} else {
|
|
1097
|
-
const { machineExec } = await import('./commands-
|
|
1097
|
+
const { machineExec } = await import('./commands-D7lgEFnK.mjs');
|
|
1098
1098
|
await machineExec(machineId, command, cwd);
|
|
1099
1099
|
}
|
|
1100
1100
|
} else if (machineSubcommand === "info") {
|
|
1101
|
-
const { machineInfo } = await import('./commands-
|
|
1101
|
+
const { machineInfo } = await import('./commands-D7lgEFnK.mjs');
|
|
1102
1102
|
let machineId;
|
|
1103
1103
|
for (let i = 1; i < machineArgs.length; i++) {
|
|
1104
1104
|
if ((machineArgs[i] === "--machine" || machineArgs[i] === "-m") && i + 1 < machineArgs.length) {
|
|
@@ -1118,10 +1118,10 @@ async function handleMachineCommand() {
|
|
|
1118
1118
|
level = machineArgs[++i];
|
|
1119
1119
|
}
|
|
1120
1120
|
}
|
|
1121
|
-
const { machineNotify } = await import('./agentCommands-
|
|
1121
|
+
const { machineNotify } = await import('./agentCommands-Ccto8aSC.mjs');
|
|
1122
1122
|
await machineNotify(message, level);
|
|
1123
1123
|
} else if (machineSubcommand === "ls") {
|
|
1124
|
-
const { machineLs } = await import('./commands-
|
|
1124
|
+
const { machineLs } = await import('./commands-D7lgEFnK.mjs');
|
|
1125
1125
|
let machineId;
|
|
1126
1126
|
let showHidden = false;
|
|
1127
1127
|
let path;
|
|
@@ -1177,20 +1177,20 @@ Examples:
|
|
|
1177
1177
|
};
|
|
1178
1178
|
const hasFlag = (name) => fleetArgs.includes(`--${name}`);
|
|
1179
1179
|
if (sub === "status") {
|
|
1180
|
-
const { fleetStatus } = await import('./fleet-
|
|
1180
|
+
const { fleetStatus } = await import('./fleet-DF-itBd1.mjs');
|
|
1181
1181
|
await fleetStatus();
|
|
1182
1182
|
} else if (sub === "upgrade-claude") {
|
|
1183
|
-
const { fleetUpgradeClaude } = await import('./fleet-
|
|
1183
|
+
const { fleetUpgradeClaude } = await import('./fleet-DF-itBd1.mjs');
|
|
1184
1184
|
await fleetUpgradeClaude({ version: flag("version", "-v") });
|
|
1185
1185
|
} else if (sub === "upgrade-svamp") {
|
|
1186
|
-
const { fleetUpgradeSvamp } = await import('./fleet-
|
|
1186
|
+
const { fleetUpgradeSvamp } = await import('./fleet-DF-itBd1.mjs');
|
|
1187
1187
|
await fleetUpgradeSvamp({ version: flag("version", "-v"), excludeSelf: hasFlag("exclude-self") });
|
|
1188
1188
|
} else if (sub === "daemon-restart") {
|
|
1189
|
-
const { fleetDaemonRestart } = await import('./fleet-
|
|
1189
|
+
const { fleetDaemonRestart } = await import('./fleet-DF-itBd1.mjs');
|
|
1190
1190
|
await fleetDaemonRestart({ graceful: !hasFlag("cleanup") });
|
|
1191
1191
|
} else if (sub === "push-skill") {
|
|
1192
1192
|
const name = fleetArgs[1];
|
|
1193
|
-
const { fleetPushSkill } = await import('./fleet-
|
|
1193
|
+
const { fleetPushSkill } = await import('./fleet-DF-itBd1.mjs');
|
|
1194
1194
|
await fleetPushSkill(name);
|
|
1195
1195
|
} else {
|
|
1196
1196
|
console.error(`Unknown fleet subcommand: ${sub}`);
|
|
@@ -1206,7 +1206,7 @@ async function handleSkillsCommand() {
|
|
|
1206
1206
|
await printSkillsHelp();
|
|
1207
1207
|
return;
|
|
1208
1208
|
}
|
|
1209
|
-
const { skillsFind, skillsInstall, skillsList, skillsRemove, skillsPublish } = await import('./commands-
|
|
1209
|
+
const { skillsFind, skillsInstall, skillsList, skillsRemove, skillsPublish } = await import('./commands-CXEWlpdy.mjs');
|
|
1210
1210
|
if (skillsSubcommand === "find" || skillsSubcommand === "search") {
|
|
1211
1211
|
const query = skillsArgs.slice(1).filter((a) => !a.startsWith("--")).join(" ");
|
|
1212
1212
|
if (!query) {
|
|
@@ -1253,7 +1253,7 @@ async function loginToHypha() {
|
|
|
1253
1253
|
process.exit(1);
|
|
1254
1254
|
}
|
|
1255
1255
|
const anchor = anchorArg.replace(/\/+$/, "");
|
|
1256
|
-
const { loadInstanceConfig } = await import('./run-
|
|
1256
|
+
const { loadInstanceConfig } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a8; });
|
|
1257
1257
|
let cfg = null;
|
|
1258
1258
|
try {
|
|
1259
1259
|
cfg = await loadInstanceConfig({ anchor, force: true });
|
|
@@ -1364,7 +1364,7 @@ async function logoutFromHypha() {
|
|
|
1364
1364
|
} catch {
|
|
1365
1365
|
}
|
|
1366
1366
|
try {
|
|
1367
|
-
const { clearInstanceConfigCache } = await import('./run-
|
|
1367
|
+
const { clearInstanceConfigCache } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a8; });
|
|
1368
1368
|
clearInstanceConfigCache();
|
|
1369
1369
|
} catch {
|
|
1370
1370
|
}
|
|
@@ -1702,7 +1702,7 @@ async function applyClaudeAuthFlags(argv) {
|
|
|
1702
1702
|
"--use-hypha-proxy, --use-claude-login, and --anthropic-base-url/--anthropic-api-key are mutually exclusive"
|
|
1703
1703
|
);
|
|
1704
1704
|
}
|
|
1705
|
-
const mod = await import('./run-
|
|
1705
|
+
const mod = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a7; });
|
|
1706
1706
|
if (hasHypha) {
|
|
1707
1707
|
let url;
|
|
1708
1708
|
const hyphaIdx = argv.indexOf("--use-hypha-proxy");
|
|
@@ -1756,7 +1756,7 @@ async function applyDaemonShareFlag(argv) {
|
|
|
1756
1756
|
}
|
|
1757
1757
|
}
|
|
1758
1758
|
if (collected.length === 0) return;
|
|
1759
|
-
const { updateEnvFile } = await import('./run-
|
|
1759
|
+
const { updateEnvFile } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a7; });
|
|
1760
1760
|
const seen = /* @__PURE__ */ new Set();
|
|
1761
1761
|
const deduped = collected.filter((e) => {
|
|
1762
1762
|
const k = e.toLowerCase();
|
|
@@ -1789,7 +1789,7 @@ async function handleWiseAgentCommand(rest) {
|
|
|
1789
1789
|
}
|
|
1790
1790
|
});
|
|
1791
1791
|
const message = rest.slice(1).map((a, idx) => ({ a, idx: idx + 1 })).filter(({ a, idx }) => !a.startsWith("-") && !consumed.has(String(idx))).map(({ a }) => a).join(" ");
|
|
1792
|
-
const { wiseAskCli } = await import('./commands-
|
|
1792
|
+
const { wiseAskCli } = await import('./commands-D7lgEFnK.mjs');
|
|
1793
1793
|
await wiseAskCli(machineId, message, sessionId, { json });
|
|
1794
1794
|
return;
|
|
1795
1795
|
}
|
|
@@ -1801,13 +1801,56 @@ async function handleWiseAgentCommand(rest) {
|
|
|
1801
1801
|
}
|
|
1802
1802
|
return void 0;
|
|
1803
1803
|
};
|
|
1804
|
-
const { runWiseVoiceCli } = await import('./headlessCli-
|
|
1804
|
+
const { runWiseVoiceCli } = await import('./headlessCli-BQVkijQh.mjs');
|
|
1805
1805
|
await runWiseVoiceCli({ voice: valueOf(["--voice"]), wakeKeywordPath: valueOf(["--wake"]), model: valueOf(["--model"]) });
|
|
1806
1806
|
return;
|
|
1807
1807
|
}
|
|
1808
|
+
if (sub === "join-meeting" || sub === "join") {
|
|
1809
|
+
const valueOf = (flags) => {
|
|
1810
|
+
for (const f of flags) {
|
|
1811
|
+
const i = rest.indexOf(f);
|
|
1812
|
+
if (i >= 0 && rest[i + 1]) return rest[i + 1];
|
|
1813
|
+
}
|
|
1814
|
+
return void 0;
|
|
1815
|
+
};
|
|
1816
|
+
const machineId = valueOf(["--machine", "-m"]);
|
|
1817
|
+
const sessionId = rest.includes("--global") ? void 0 : valueOf(["--session", "-s"]);
|
|
1818
|
+
const json = rest.includes("--json");
|
|
1819
|
+
const url = rest.slice(1).find((a) => /^https?:\/\//.test(a)) || "";
|
|
1820
|
+
const { wiseJoinMeetingCli } = await import('./commands-D7lgEFnK.mjs');
|
|
1821
|
+
await wiseJoinMeetingCli(machineId, url, sessionId, { json });
|
|
1822
|
+
return;
|
|
1823
|
+
}
|
|
1824
|
+
if (sub === "leave-meeting" || sub === "leave") {
|
|
1825
|
+
const valueOf = (flags) => {
|
|
1826
|
+
for (const f of flags) {
|
|
1827
|
+
const i = rest.indexOf(f);
|
|
1828
|
+
if (i >= 0 && rest[i + 1]) return rest[i + 1];
|
|
1829
|
+
}
|
|
1830
|
+
return void 0;
|
|
1831
|
+
};
|
|
1832
|
+
const { wiseLeaveMeetingCli } = await import('./commands-D7lgEFnK.mjs');
|
|
1833
|
+
await wiseLeaveMeetingCli(valueOf(["--machine", "-m"]), valueOf(["--session", "-s"]), { json: rest.includes("--json") });
|
|
1834
|
+
return;
|
|
1835
|
+
}
|
|
1836
|
+
if (sub === "meetings") {
|
|
1837
|
+
const valueOf = (flags) => {
|
|
1838
|
+
for (const f of flags) {
|
|
1839
|
+
const i = rest.indexOf(f);
|
|
1840
|
+
if (i >= 0 && rest[i + 1]) return rest[i + 1];
|
|
1841
|
+
}
|
|
1842
|
+
return void 0;
|
|
1843
|
+
};
|
|
1844
|
+
const { wiseMeetingsCli } = await import('./commands-D7lgEFnK.mjs');
|
|
1845
|
+
await wiseMeetingsCli(valueOf(["--machine", "-m"]), { json: rest.includes("--json") });
|
|
1846
|
+
return;
|
|
1847
|
+
}
|
|
1808
1848
|
if (sub === "--help" || sub === "-h") {
|
|
1809
1849
|
console.log(`Usage:
|
|
1810
1850
|
svamp wise ask "<message>" [--session <id>] [-m <machine>] [--json]
|
|
1851
|
+
svamp wise join-meeting <zoom|meet|teams url> [--session <id>|--global] [-m <machine>]
|
|
1852
|
+
svamp wise leave-meeting [--session <id>] [-m <machine>]
|
|
1853
|
+
svamp wise meetings [-m <machine>]
|
|
1811
1854
|
Fast WISE turn \u2014 GLOBAL machine-manager by default (daemon status, run
|
|
1812
1855
|
commands, inspect/spawn/drive any session); --session <id> scopes to one.
|
|
1813
1856
|
|
|
@@ -1843,7 +1886,7 @@ If none is set, hitting a WISE Agent channel returns a clear "not configured" er
|
|
|
1843
1886
|
return;
|
|
1844
1887
|
}
|
|
1845
1888
|
const authArgs = rest.slice(1);
|
|
1846
|
-
const mod = await import('./auth-
|
|
1889
|
+
const mod = await import('./auth-C1V6j2MC.mjs');
|
|
1847
1890
|
let action;
|
|
1848
1891
|
try {
|
|
1849
1892
|
action = mod.parseWiseAgentAuthArgs(authArgs);
|
|
@@ -1853,7 +1896,7 @@ If none is set, hitting a WISE Agent channel returns a clear "not configured" er
|
|
|
1853
1896
|
return;
|
|
1854
1897
|
}
|
|
1855
1898
|
if (action) {
|
|
1856
|
-
const { updateEnvFile } = await import('./run-
|
|
1899
|
+
const { updateEnvFile } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a7; });
|
|
1857
1900
|
const updates = mod.buildWiseAgentEnvUpdates(action);
|
|
1858
1901
|
updateEnvFile(updates);
|
|
1859
1902
|
for (const [k, v] of Object.entries(updates)) {
|
|
@@ -1867,7 +1910,7 @@ If none is set, hitting a WISE Agent channel returns a clear "not configured" er
|
|
|
1867
1910
|
}
|
|
1868
1911
|
async function handleDaemonAuthCommand(argv) {
|
|
1869
1912
|
const sub = (argv[0] || "status").toLowerCase();
|
|
1870
|
-
const mod = await import('./run-
|
|
1913
|
+
const mod = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a7; });
|
|
1871
1914
|
if (sub === "--help" || sub === "-h" || sub === "help") {
|
|
1872
1915
|
console.log(`
|
|
1873
1916
|
svamp daemon auth \u2014 Configure how Claude subprocesses authenticate
|
|
@@ -2180,7 +2223,7 @@ Examples:
|
|
|
2180
2223
|
async function printSkillsHelp() {
|
|
2181
2224
|
let browseUrl = "<HYPHA_SERVER_URL>/<workspace>/artifacts/marketplace (set HYPHA_SERVER_URL)";
|
|
2182
2225
|
try {
|
|
2183
|
-
const { getArtifactBaseUrl, getSkillsCollectionName } = await import('./run-
|
|
2226
|
+
const { getArtifactBaseUrl, getSkillsCollectionName } = await import('./run-vPl2hvCU.mjs').then(function (n) { return n.a9; });
|
|
2184
2227
|
browseUrl = `${getArtifactBaseUrl()}/${getSkillsCollectionName()}`;
|
|
2185
2228
|
} catch {
|
|
2186
2229
|
}
|
|
@@ -58,7 +58,7 @@ async function serviceExpose(args) {
|
|
|
58
58
|
process.exit(1);
|
|
59
59
|
}
|
|
60
60
|
if (foreground) {
|
|
61
|
-
const { runFrpcTunnel } = await import('./frpc-
|
|
61
|
+
const { runFrpcTunnel } = await import('./frpc-DorJMSBi.mjs');
|
|
62
62
|
await runFrpcTunnel(name, ports, void 0, {
|
|
63
63
|
group,
|
|
64
64
|
groupKey,
|
|
@@ -68,7 +68,7 @@ async function serviceExpose(args) {
|
|
|
68
68
|
});
|
|
69
69
|
return;
|
|
70
70
|
}
|
|
71
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
71
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
72
72
|
const { server, machine } = await connectAndGetMachine();
|
|
73
73
|
try {
|
|
74
74
|
const status = await machine.tunnelStart({
|
|
@@ -123,7 +123,7 @@ async function serviceServe(args) {
|
|
|
123
123
|
};
|
|
124
124
|
process.on("SIGINT", cleanup);
|
|
125
125
|
process.on("SIGTERM", cleanup);
|
|
126
|
-
const { runFrpcTunnel } = await import('./frpc-
|
|
126
|
+
const { runFrpcTunnel } = await import('./frpc-DorJMSBi.mjs');
|
|
127
127
|
await runFrpcTunnel(name, [caddyPort]);
|
|
128
128
|
} catch (err) {
|
|
129
129
|
console.error(`Error serving directory: ${err.message}`);
|
|
@@ -132,7 +132,7 @@ async function serviceServe(args) {
|
|
|
132
132
|
}
|
|
133
133
|
async function serviceList(_args) {
|
|
134
134
|
try {
|
|
135
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
135
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
136
136
|
const { server, machine } = await connectAndGetMachine();
|
|
137
137
|
try {
|
|
138
138
|
const tunnels = await machine.tunnelList({});
|
|
@@ -172,7 +172,7 @@ async function serviceDelete(args) {
|
|
|
172
172
|
process.exit(1);
|
|
173
173
|
}
|
|
174
174
|
try {
|
|
175
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
175
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
176
176
|
const { server, machine } = await connectAndGetMachine();
|
|
177
177
|
try {
|
|
178
178
|
await machine.tunnelStop({ name });
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import os from 'os';
|
|
2
2
|
import fs__default from 'fs';
|
|
3
3
|
import { resolve, join, relative } from 'path';
|
|
4
|
-
import { p as parseFrontmatter, n as getSkillsServer, o as getSkillsWorkspaceName, q as getSkillsCollectionName, t as fetchWithTimeout, u as searchSkills, v as SKILLS_DIR, w as getSkillInfo, x as downloadSkillFile, y as listSkillFiles } from './run-
|
|
4
|
+
import { p as parseFrontmatter, n as getSkillsServer, o as getSkillsWorkspaceName, q as getSkillsCollectionName, t as fetchWithTimeout, u as searchSkills, v as SKILLS_DIR, w as getSkillInfo, x as downloadSkillFile, y as listSkillFiles } from './run-vPl2hvCU.mjs';
|
|
5
5
|
import 'fs/promises';
|
|
6
6
|
import 'url';
|
|
7
7
|
import 'child_process';
|
|
@@ -2,7 +2,7 @@ import { existsSync, readFileSync, writeFileSync } from 'node:fs';
|
|
|
2
2
|
import { execSync } from 'node:child_process';
|
|
3
3
|
import { basename, resolve, join, isAbsolute } from 'node:path';
|
|
4
4
|
import os from 'node:os';
|
|
5
|
-
import { I as formatHandle, J as normalizeAllowedUser, K as loadSecurityContextConfig, L as resolveSecurityContext, M as buildSecurityContextFromFlags, N as mergeSecurityContexts, c as connectToHypha, O as buildSessionShareUrl, P as validateChecklist, Q as computeOutboundHop, m as shortId, T as buildMachineShareUrl, U as summarize, V as newItem, W as parseHandle, X as handleMatchesMetadata } from './run-
|
|
5
|
+
import { I as formatHandle, J as normalizeAllowedUser, K as loadSecurityContextConfig, L as resolveSecurityContext, M as buildSecurityContextFromFlags, N as mergeSecurityContexts, c as connectToHypha, O as buildSessionShareUrl, P as validateChecklist, Q as computeOutboundHop, m as shortId, T as buildMachineShareUrl, U as summarize, V as newItem, W as parseHandle, X as handleMatchesMetadata } from './run-vPl2hvCU.mjs';
|
|
6
6
|
import 'os';
|
|
7
7
|
import 'fs/promises';
|
|
8
8
|
import 'fs';
|
|
@@ -2337,6 +2337,62 @@ async function wiseAskCli(machineId, message, sessionId, opts) {
|
|
|
2337
2337
|
await server.disconnect();
|
|
2338
2338
|
}
|
|
2339
2339
|
}
|
|
2340
|
+
async function wiseJoinMeetingCli(machineId, url, sessionId, opts) {
|
|
2341
|
+
if (!url) {
|
|
2342
|
+
console.error("Usage: svamp wise join-meeting <zoom|meet|teams url> [--session <id>|--global] [-m <machine>]");
|
|
2343
|
+
process.exit(1);
|
|
2344
|
+
}
|
|
2345
|
+
const { server, machine } = await connectAndGetMachine(machineId);
|
|
2346
|
+
try {
|
|
2347
|
+
const res = await machine.wiseJoinMeeting({ meetingUrl: url, sessionId });
|
|
2348
|
+
if (opts?.json) {
|
|
2349
|
+
console.log(JSON.stringify(res, null, 2));
|
|
2350
|
+
process.exit(res?.success ? 0 : 1);
|
|
2351
|
+
}
|
|
2352
|
+
if (res?.error) {
|
|
2353
|
+
console.error(`\u2717 ${res.error}`);
|
|
2354
|
+
process.exit(1);
|
|
2355
|
+
}
|
|
2356
|
+
console.log(`\u2713 WISE joining ${res.platform} meeting ${res.nativeId} (${res.target})${res.meetingId ? ` \u2014 meeting #${res.meetingId}` : ""}`);
|
|
2357
|
+
process.exit(0);
|
|
2358
|
+
} finally {
|
|
2359
|
+
await server.disconnect();
|
|
2360
|
+
}
|
|
2361
|
+
}
|
|
2362
|
+
async function wiseLeaveMeetingCli(machineId, sessionId, opts) {
|
|
2363
|
+
const { server, machine } = await connectAndGetMachine(machineId);
|
|
2364
|
+
try {
|
|
2365
|
+
const res = await machine.wiseLeaveMeeting({ sessionId });
|
|
2366
|
+
if (opts?.json) {
|
|
2367
|
+
console.log(JSON.stringify(res, null, 2));
|
|
2368
|
+
process.exit(res?.success ? 0 : 1);
|
|
2369
|
+
}
|
|
2370
|
+
if (res?.error) {
|
|
2371
|
+
console.error(`\u2717 ${res.error}`);
|
|
2372
|
+
process.exit(1);
|
|
2373
|
+
}
|
|
2374
|
+
console.log("\u2713 WISE left the meeting");
|
|
2375
|
+
process.exit(0);
|
|
2376
|
+
} finally {
|
|
2377
|
+
await server.disconnect();
|
|
2378
|
+
}
|
|
2379
|
+
}
|
|
2380
|
+
async function wiseMeetingsCli(machineId, opts) {
|
|
2381
|
+
const { server, machine } = await connectAndGetMachine(machineId);
|
|
2382
|
+
try {
|
|
2383
|
+
const res = await machine.wiseMeetingStatus({});
|
|
2384
|
+
if (opts?.json) {
|
|
2385
|
+
console.log(JSON.stringify(res, null, 2));
|
|
2386
|
+
process.exit(0);
|
|
2387
|
+
}
|
|
2388
|
+
const ms = res?.meetings || [];
|
|
2389
|
+
if (!ms.length) console.log("No active meeting agents.");
|
|
2390
|
+
else for (const m of ms) console.log(`\u2022 ${m.platform} ${m.nativeId} \u2014 ${m.target}${m.meetingId ? ` (#${m.meetingId})` : ""}`);
|
|
2391
|
+
process.exit(0);
|
|
2392
|
+
} finally {
|
|
2393
|
+
await server.disconnect();
|
|
2394
|
+
}
|
|
2395
|
+
}
|
|
2340
2396
|
async function machineInfo(machineId) {
|
|
2341
2397
|
const { server, machine } = await connectAndGetMachine(machineId);
|
|
2342
2398
|
try {
|
|
@@ -2717,4 +2773,4 @@ async function sessionInboxClear(sessionIdPartial, machineId, opts) {
|
|
|
2717
2773
|
}
|
|
2718
2774
|
}
|
|
2719
2775
|
|
|
2720
|
-
export { checklistConfigPatch, collectAssistantResponse, connectAndGetMachine, connectAndResolveSession, createWorktree, generateWorktreeName, machineExec, machineInfo, machineLs, machineShare, mutateChecklistItems, parseShareArg, queryCore, renderMessage, resolveItemIds, resolveSessionId, sendCore, sessionApprove, sessionArchive, sessionAttach, sessionChecklist, sessionDelete, sessionDeny, sessionEditMessage, sessionInboxClear, sessionInboxList, sessionInboxRead, sessionInboxReply, sessionInboxSend, sessionInfo, sessionList, sessionLoopCancel, sessionLoopStart, sessionLoopStatus, sessionMachines, sessionMessages, sessionQuery, sessionRefineLastReply, sessionResume, sessionSend, sessionShare, sessionSpawn, sessionUndoEdit, sessionWait, sessionWhoami, snapshotLatestSeq, validateSendOptions, wiseAskCli };
|
|
2776
|
+
export { checklistConfigPatch, collectAssistantResponse, connectAndGetMachine, connectAndResolveSession, createWorktree, generateWorktreeName, machineExec, machineInfo, machineLs, machineShare, mutateChecklistItems, parseShareArg, queryCore, renderMessage, resolveItemIds, resolveSessionId, sendCore, sessionApprove, sessionArchive, sessionAttach, sessionChecklist, sessionDelete, sessionDeny, sessionEditMessage, sessionInboxClear, sessionInboxList, sessionInboxRead, sessionInboxReply, sessionInboxSend, sessionInfo, sessionList, sessionLoopCancel, sessionLoopStart, sessionLoopStatus, sessionMachines, sessionMessages, sessionQuery, sessionRefineLastReply, sessionResume, sessionSend, sessionShare, sessionSpawn, sessionUndoEdit, sessionWait, sessionWhoami, snapshotLatestSeq, validateSendOptions, wiseAskCli, wiseJoinMeetingCli, wiseLeaveMeetingCli, wiseMeetingsCli };
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { existsSync } from 'node:fs';
|
|
2
|
-
import { connectAndGetMachine, resolveSessionId, createWorktree, connectAndResolveSession } from './commands-
|
|
2
|
+
import { connectAndGetMachine, resolveSessionId, createWorktree, connectAndResolveSession } from './commands-D7lgEFnK.mjs';
|
|
3
3
|
import { execSync } from 'node:child_process';
|
|
4
|
-
import { m as shortId } from './run-
|
|
4
|
+
import { m as shortId } from './run-vPl2hvCU.mjs';
|
|
5
5
|
import 'node:path';
|
|
6
6
|
import 'node:os';
|
|
7
7
|
import 'os';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { execSync, execFileSync } from 'node:child_process';
|
|
2
2
|
import { randomUUID } from 'node:crypto';
|
|
3
3
|
import { createServer } from 'node:http';
|
|
4
|
-
import { E as readChecklist, F as compileChecklist, G as RoutineStore, H as RoutineRunner } from './run-
|
|
4
|
+
import { E as readChecklist, F as compileChecklist, G as RoutineStore, H as RoutineRunner } from './run-vPl2hvCU.mjs';
|
|
5
5
|
import 'os';
|
|
6
6
|
import 'fs/promises';
|
|
7
7
|
import 'fs';
|
|
@@ -104,7 +104,7 @@ Criteria: ${res.criteria || "(none)"}
|
|
|
104
104
|
urgency: "normal",
|
|
105
105
|
hopCount: 1
|
|
106
106
|
};
|
|
107
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
107
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
108
108
|
const { server, machine } = await connectAndGetMachine();
|
|
109
109
|
try {
|
|
110
110
|
await machine.sessionRPC(reportTo, "sendInboxMessage", { message });
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { writeFileSync, readFileSync } from 'fs';
|
|
2
2
|
import { resolve } from 'path';
|
|
3
|
-
import { connectAndGetMachine } from './commands-
|
|
3
|
+
import { connectAndGetMachine } from './commands-D7lgEFnK.mjs';
|
|
4
4
|
import 'node:fs';
|
|
5
5
|
import 'node:child_process';
|
|
6
6
|
import 'node:path';
|
|
7
7
|
import 'node:os';
|
|
8
|
-
import './run-
|
|
8
|
+
import './run-vPl2hvCU.mjs';
|
|
9
9
|
import 'os';
|
|
10
10
|
import 'fs/promises';
|
|
11
11
|
import 'url';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { existsSync, readFileSync } from 'node:fs';
|
|
2
2
|
import { join } from 'node:path';
|
|
3
3
|
import os from 'node:os';
|
|
4
|
-
import { c as connectToHypha } from './run-
|
|
4
|
+
import { c as connectToHypha } from './run-vPl2hvCU.mjs';
|
|
5
5
|
import { PINNED_CLAUDE_CODE_VERSION } from './pinnedClaudeCode-HydRNEt7.mjs';
|
|
6
6
|
import 'os';
|
|
7
7
|
import 'fs/promises';
|
|
@@ -4,7 +4,7 @@ import { mkdirSync, writeFileSync, unlinkSync, existsSync, chmodSync, readFileSy
|
|
|
4
4
|
import { join } from 'path';
|
|
5
5
|
import { homedir, platform, arch } from 'os';
|
|
6
6
|
import { randomUUID, createHash } from 'crypto';
|
|
7
|
-
import { h as getFrpsSubdomainHost, i as getFrpsServerPort, j as getFrpsServerAddr } from './run-
|
|
7
|
+
import { h as getFrpsSubdomainHost, i as getFrpsServerPort, j as getFrpsServerAddr } from './run-vPl2hvCU.mjs';
|
|
8
8
|
import 'fs/promises';
|
|
9
9
|
import 'url';
|
|
10
10
|
import 'node:crypto';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { D as resolveModel, Y as describeMisconfiguration, Z as buildMachineDeps } from './run-
|
|
2
|
-
import { handleRealtimeEvent, initMachineVoiceSession } from './sideband
|
|
1
|
+
import { D as resolveModel, Y as describeMisconfiguration, Z as buildMachineDeps } from './run-vPl2hvCU.mjs';
|
|
2
|
+
import { handleRealtimeEvent, initMachineVoiceSession } from './sideband-Cg0Ttcuj.mjs';
|
|
3
3
|
import { WebSocket } from 'ws';
|
|
4
4
|
import { execSync, spawn } from 'child_process';
|
|
5
5
|
import 'os';
|
package/dist/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { c as connectToHypha, a as createSessionStore, d as daemonStatus, g as getHyphaServerUrl, r as registerMachineService, s as startDaemon, b as stopDaemon } from './run-
|
|
1
|
+
export { c as connectToHypha, a as createSessionStore, d as daemonStatus, g as getHyphaServerUrl, r as registerMachineService, s as startDaemon, b as stopDaemon } from './run-vPl2hvCU.mjs';
|
|
2
2
|
import 'os';
|
|
3
3
|
import 'fs/promises';
|
|
4
4
|
import 'fs';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
var name = "svamp-cli";
|
|
2
|
-
var version = "0.2.
|
|
2
|
+
var version = "0.2.141";
|
|
3
3
|
var description = "Svamp CLI — AI workspace daemon on Hypha Cloud";
|
|
4
4
|
var author = "Amun AI AB";
|
|
5
5
|
var license = "SEE LICENSE IN LICENSE";
|
|
@@ -19,7 +19,7 @@ var exports$1 = {
|
|
|
19
19
|
var scripts = {
|
|
20
20
|
build: "rm -rf dist bin/skills && mkdir -p bin/skills && cp -r ../../skills/artifact bin/skills/artifact && cp -r ../../skills/loop bin/skills/loop && cp -r ../../skills/crew bin/skills/crew && tsc --noEmit && pkgroll",
|
|
21
21
|
typecheck: "tsc --noEmit",
|
|
22
|
-
test: "npx tsx test/test-context-window.mjs && npx tsx test/test-ratelimit-retry.mjs && npx tsx test/test-instance-config.mjs && npx tsx test/test-authorize.mjs && npx tsx test/test-normalize-allowed-user.mjs && npx tsx test/test-share-url.mjs && npx tsx test/test-update-sharing-normalization.mjs && npx tsx test/test-staged-homes-sweep.mjs && npx tsx test/test-session-helpers.mjs && npx tsx test/test-cli-routing.mjs && npx tsx test/test-security-context.mjs && npx tsx test/test-isolation-decision.mjs && npx tsx test/test-loop-activation.mjs && npx tsx test/test-message-helpers.mjs && npx tsx test/test-agent-config.mjs && npx tsx test/test-wrap-command.mjs && npx tsx test/test-credential-staging.mjs && npx tsx test/test-claude-auth.mjs && npx tsx test/test-output-formatters.mjs && npx tsx test/test-inbox-guard.mjs && npx tsx test/test-auto-topic.mjs && npx tsx test/test-project-info.mjs && npx tsx test/test-agent-types.mjs && npx tsx test/test-transport.mjs && npx tsx test/test-session-update-handlers.mjs && npx tsx test/test-session-scanner.mjs && npx tsx test/test-hypha-client.mjs && npx tsx test/test-hook-settings.mjs && npx tsx test/test-session-service-logic.mjs && npx tsx test/test-daemon-persistence.mjs && npx tsx test/test-detect-isolation.mjs && npx tsx test/test-machine-service-logic.mjs && npx tsx test/test-interactive-helpers.mjs && npx tsx test/test-codex-backend.mjs && npx tsx test/test-acp-backend.mjs && npx tsx test/test-acp-bridge.mjs && npx tsx test/test-hook-server.mjs && npx tsx test/test-session-commands.mjs && npx tsx test/test-interactive-console.mjs && npx tsx test/test-session-messages.mjs && npx tsx test/test-session-send-query.mjs && npx tsx test/test-skills.mjs && npx tsx test/test-agent-grouping.mjs && npx tsx test/test-machine-list-directory.mjs && npx tsx test/test-service-commands.mjs && npx tsx test/test-supervisor.mjs && npx tsx test/test-supervisor-lock.mjs && node test/test-supervisor-restart.mjs && npx tsx test/test-clear-detection.mjs && npx tsx test/test-session-consolidation.mjs && npx tsx test/test-inbox.mjs && npx tsx test/test-checklist.mjs && npx tsx test/test-checklist-cli.mjs && npx tsx test/test-short-id.mjs && npx tsx test/test-transcript-edit.mjs && npx tsx test/test-edit-history.mjs && npx tsx test/test-friendly-name.mjs && npx tsx test/test-session-rpc-dispatch.mjs && npx tsx test/test-sandbox-cli.mjs && npx tsx test/test-serve-manager.mjs && npx tsx test/test-serve-stability.mjs && npx tsx test/test-frpc-e2e.mjs --unit-only && npx tsx test/test-frpc-status.mjs && node test/pinnedClaudeCode.test.mjs && node test/fleet.test.mjs && npx tsx test/test-routine.mjs && npx tsx test/test-routine-rpc.mjs && npx tsx test/test-checklist-watchdog.mjs && npx tsx test/test-session-file.mjs && npx tsx test/test-channel-rpc.mjs && npx tsx test/test-wise-agent.mjs && npx tsx test/test-channel-agent.mjs && npx tsx test/test-channels-service.mjs && npx tsx test/test-channel-async-reply.mjs && npx tsx test/test-channel-binding.mjs && npx tsx test/test-channel-identity.mjs && npx tsx test/test-shared-session-identity.mjs && npx tsx test/test-wise-agent-auth.mjs && npx tsx test/test-channel-http.mjs && npx tsx test/test-wise-voice.mjs && npx tsx test/test-wise-headless.mjs && npx tsx test/test-wise-machine.mjs && npx tsx test/test-crew-merge.mjs",
|
|
22
|
+
test: "npx tsx test/test-context-window.mjs && npx tsx test/test-ratelimit-retry.mjs && npx tsx test/test-instance-config.mjs && npx tsx test/test-authorize.mjs && npx tsx test/test-normalize-allowed-user.mjs && npx tsx test/test-share-url.mjs && npx tsx test/test-update-sharing-normalization.mjs && npx tsx test/test-staged-homes-sweep.mjs && npx tsx test/test-session-helpers.mjs && npx tsx test/test-cli-routing.mjs && npx tsx test/test-security-context.mjs && npx tsx test/test-isolation-decision.mjs && npx tsx test/test-loop-activation.mjs && npx tsx test/test-message-helpers.mjs && npx tsx test/test-agent-config.mjs && npx tsx test/test-wrap-command.mjs && npx tsx test/test-credential-staging.mjs && npx tsx test/test-claude-auth.mjs && npx tsx test/test-output-formatters.mjs && npx tsx test/test-inbox-guard.mjs && npx tsx test/test-auto-topic.mjs && npx tsx test/test-project-info.mjs && npx tsx test/test-agent-types.mjs && npx tsx test/test-transport.mjs && npx tsx test/test-session-update-handlers.mjs && npx tsx test/test-session-scanner.mjs && npx tsx test/test-hypha-client.mjs && npx tsx test/test-hook-settings.mjs && npx tsx test/test-session-service-logic.mjs && npx tsx test/test-daemon-persistence.mjs && npx tsx test/test-detect-isolation.mjs && npx tsx test/test-machine-service-logic.mjs && npx tsx test/test-interactive-helpers.mjs && npx tsx test/test-codex-backend.mjs && npx tsx test/test-acp-backend.mjs && npx tsx test/test-acp-bridge.mjs && npx tsx test/test-hook-server.mjs && npx tsx test/test-session-commands.mjs && npx tsx test/test-interactive-console.mjs && npx tsx test/test-session-messages.mjs && npx tsx test/test-session-send-query.mjs && npx tsx test/test-skills.mjs && npx tsx test/test-agent-grouping.mjs && npx tsx test/test-machine-list-directory.mjs && npx tsx test/test-service-commands.mjs && npx tsx test/test-supervisor.mjs && npx tsx test/test-supervisor-lock.mjs && node test/test-supervisor-restart.mjs && npx tsx test/test-clear-detection.mjs && npx tsx test/test-session-consolidation.mjs && npx tsx test/test-inbox.mjs && npx tsx test/test-checklist.mjs && npx tsx test/test-checklist-cli.mjs && npx tsx test/test-serve-link-subdomain.mjs && npx tsx test/test-short-id.mjs && npx tsx test/test-transcript-edit.mjs && npx tsx test/test-edit-history.mjs && npx tsx test/test-friendly-name.mjs && npx tsx test/test-session-rpc-dispatch.mjs && npx tsx test/test-sandbox-cli.mjs && npx tsx test/test-serve-manager.mjs && npx tsx test/test-serve-stability.mjs && npx tsx test/test-frpc-e2e.mjs --unit-only && npx tsx test/test-frpc-status.mjs && node test/pinnedClaudeCode.test.mjs && node test/fleet.test.mjs && npx tsx test/test-routine.mjs && npx tsx test/test-routine-rpc.mjs && npx tsx test/test-checklist-watchdog.mjs && npx tsx test/test-session-file.mjs && npx tsx test/test-channel-rpc.mjs && npx tsx test/test-wise-agent.mjs && npx tsx test/test-channel-agent.mjs && npx tsx test/test-channels-service.mjs && npx tsx test/test-channel-async-reply.mjs && npx tsx test/test-channel-binding.mjs && npx tsx test/test-channel-identity.mjs && npx tsx test/test-shared-session-identity.mjs && npx tsx test/test-wise-agent-auth.mjs && npx tsx test/test-channel-http.mjs && npx tsx test/test-wise-voice.mjs && npx tsx test/test-wise-headless.mjs && npx tsx test/test-wise-machine.mjs && npx tsx test/test-crew-merge.mjs",
|
|
23
23
|
"test:hypha": "node --no-warnings test/test-hypha-service.mjs",
|
|
24
24
|
dev: "tsx src/cli.ts",
|
|
25
25
|
"dev:daemon": "tsx src/cli.ts daemon start-sync",
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{createRequire as _pkgrollCR}from"node:module";const require=_pkgrollCR(import.meta.url);import { _ as composeSessionId, $ as generateFriendlyName, c as connectToHypha, a as createSessionStore, r as registerMachineService, a0 as generateHookSettings } from './run-
|
|
1
|
+
import{createRequire as _pkgrollCR}from"node:module";const require=_pkgrollCR(import.meta.url);import { _ as composeSessionId, $ as generateFriendlyName, c as connectToHypha, a as createSessionStore, r as registerMachineService, a0 as generateHookSettings } from './run-vPl2hvCU.mjs';
|
|
2
2
|
import os from 'node:os';
|
|
3
3
|
import { resolve, join } from 'node:path';
|
|
4
4
|
import { existsSync, readFileSync, watch } from 'node:fs';
|
|
@@ -1692,6 +1692,26 @@ async function mintRealtimeEphemeralKey(baseUrl, apiKey, opts) {
|
|
|
1692
1692
|
clearTimeout(timer);
|
|
1693
1693
|
}
|
|
1694
1694
|
}
|
|
1695
|
+
const activeMeetingAgents = /* @__PURE__ */ new Map();
|
|
1696
|
+
function parseMeetingUrl(raw) {
|
|
1697
|
+
const s = (raw || "").trim();
|
|
1698
|
+
try {
|
|
1699
|
+
const u = new URL(s);
|
|
1700
|
+
const h = u.hostname.toLowerCase();
|
|
1701
|
+
if (h.includes("zoom")) {
|
|
1702
|
+
const m = u.pathname.match(/\/(?:j|wc|s)\/(\d{8,})/) || s.match(/(\d{9,})/);
|
|
1703
|
+
return m ? { platform: "zoom", nativeId: m[1] } : null;
|
|
1704
|
+
}
|
|
1705
|
+
if (h.includes("meet.google")) {
|
|
1706
|
+
const m = u.pathname.match(/([a-z]{3}-[a-z]{4}-[a-z]{3})/i);
|
|
1707
|
+
return m ? { platform: "google_meet", nativeId: m[1] } : null;
|
|
1708
|
+
}
|
|
1709
|
+
if (h.includes("teams.")) return { platform: "teams", nativeId: s };
|
|
1710
|
+
return null;
|
|
1711
|
+
} catch {
|
|
1712
|
+
return null;
|
|
1713
|
+
}
|
|
1714
|
+
}
|
|
1695
1715
|
async function mintTranscriptionEphemeralKey(baseUrl, apiKey, opts) {
|
|
1696
1716
|
const realtimeBase = baseUrl || "https://api.openai.com";
|
|
1697
1717
|
const ctrl = new AbortController();
|
|
@@ -2680,7 +2700,7 @@ async function registerMachineService(server, machineId, metadata, daemonState,
|
|
|
2680
2700
|
const tunnels = handlers.tunnels;
|
|
2681
2701
|
if (!tunnels) throw new Error("Tunnel management not available");
|
|
2682
2702
|
if (tunnels.has(params.name)) throw new Error(`Tunnel '${params.name}' already running`);
|
|
2683
|
-
const { FrpcTunnel } = await import('./frpc-
|
|
2703
|
+
const { FrpcTunnel } = await import('./frpc-DorJMSBi.mjs');
|
|
2684
2704
|
const tunnel = new FrpcTunnel({
|
|
2685
2705
|
name: params.name,
|
|
2686
2706
|
ports: params.ports,
|
|
@@ -2773,7 +2793,7 @@ async function registerMachineService(server, machineId, metadata, daemonState,
|
|
|
2773
2793
|
authorizeRequest(context, currentMetadata.sharing, "interact");
|
|
2774
2794
|
const sm = handlers.serveManager;
|
|
2775
2795
|
if (!sm) throw new Error("Serve manager not available");
|
|
2776
|
-
const ownerEmail2 = params.ownerEmail || context?.user?.email || void 0;
|
|
2796
|
+
const ownerEmail2 = params.ownerEmail || context?.user?.email || currentMetadata.sharing?.owner || process.env.SVAMP_OWNER_EMAIL || void 0;
|
|
2777
2797
|
const access = params.access || "owner";
|
|
2778
2798
|
return sm.addMount(params.name, params.directory, params.sessionId, access, ownerEmail2);
|
|
2779
2799
|
},
|
|
@@ -2786,7 +2806,7 @@ async function registerMachineService(server, machineId, metadata, daemonState,
|
|
|
2786
2806
|
authorizeRequest(context, currentMetadata.sharing, "interact");
|
|
2787
2807
|
const sm = handlers.serveManager;
|
|
2788
2808
|
if (!sm) throw new Error("Serve manager not available");
|
|
2789
|
-
const ownerEmail2 = params.ownerEmail || context?.user?.email || void 0;
|
|
2809
|
+
const ownerEmail2 = params.ownerEmail || context?.user?.email || currentMetadata.sharing?.owner || process.env.SVAMP_OWNER_EMAIL || void 0;
|
|
2790
2810
|
const access = params.access ?? "owner";
|
|
2791
2811
|
return sm.applyMount({
|
|
2792
2812
|
name: params.name,
|
|
@@ -2874,6 +2894,58 @@ async function registerMachineService(server, machineId, metadata, daemonState,
|
|
|
2874
2894
|
return { success: false, error: error instanceof Error ? error.message : "Failed to create token" };
|
|
2875
2895
|
}
|
|
2876
2896
|
},
|
|
2897
|
+
// --- WISE meeting agent: launch/stop the in-meeting voice agent ---
|
|
2898
|
+
// Parses a Zoom/Meet/Teams link, POSTs to the self-hosted Vexa meeting-api
|
|
2899
|
+
// (SVAMP_VEXA_API_URL + SVAMP_VEXA_API_KEY) which spawns a bot pod that runs
|
|
2900
|
+
// the realtime WISE voice loop (connected to this session's WISE agent).
|
|
2901
|
+
// sessionId set = attached to that session; omitted = global.
|
|
2902
|
+
wiseJoinMeeting: async (params, context) => {
|
|
2903
|
+
if (context && (!context.user || context.user.is_anonymous)) return { success: false, error: "Sign in to launch a meeting agent." };
|
|
2904
|
+
const parsed = parseMeetingUrl(params?.meetingUrl || "");
|
|
2905
|
+
if (!parsed) return { success: false, error: "Unrecognized meeting link (supports Zoom, Google Meet, Teams)." };
|
|
2906
|
+
const base = (process.env.SVAMP_VEXA_API_URL || "").replace(/\/$/, "");
|
|
2907
|
+
const key = process.env.SVAMP_VEXA_API_KEY || "";
|
|
2908
|
+
if (!base || !key) return { success: false, error: "Meeting agent not configured: set SVAMP_VEXA_API_URL + SVAMP_VEXA_API_KEY in ~/.svamp/.env, then `svamp daemon restart`." };
|
|
2909
|
+
try {
|
|
2910
|
+
const res = await fetch(`${base}/bots`, {
|
|
2911
|
+
method: "POST",
|
|
2912
|
+
headers: { "X-API-Key": key, "Content-Type": "application/json" },
|
|
2913
|
+
body: JSON.stringify({ platform: parsed.platform, native_meeting_id: parsed.nativeId, bot_name: "WISE Agent" })
|
|
2914
|
+
});
|
|
2915
|
+
const data = await res.json().catch(() => ({}));
|
|
2916
|
+
if (!res.ok) return { success: false, error: `meeting-api ${res.status}: ${data?.detail || data?.message || "launch failed"}` };
|
|
2917
|
+
const rec = { meetingUrl: params.meetingUrl, platform: parsed.platform, nativeId: parsed.nativeId, target: params.sessionId ? `session:${params.sessionId}` : "global", sessionId: params.sessionId, botId: data?.bot_container_id, meetingId: data?.id, startedAt: Date.now() };
|
|
2918
|
+
activeMeetingAgents.set(params.sessionId || `global:${parsed.nativeId}`, rec);
|
|
2919
|
+
return { success: true, ...rec, status: data?.status };
|
|
2920
|
+
} catch (e) {
|
|
2921
|
+
return { success: false, error: e instanceof Error ? e.message : "join failed" };
|
|
2922
|
+
}
|
|
2923
|
+
},
|
|
2924
|
+
wiseLeaveMeeting: async (params, context) => {
|
|
2925
|
+
if (context && (!context.user || context.user.is_anonymous)) return { success: false, error: "Sign in." };
|
|
2926
|
+
const k = params?.sessionId || (params?.platform && params?.nativeId ? `global:${params.nativeId}` : "");
|
|
2927
|
+
const rec = k ? activeMeetingAgents.get(k) : void 0;
|
|
2928
|
+
const platform = params?.platform || rec?.platform;
|
|
2929
|
+
const nativeId = params?.nativeId || rec?.nativeId;
|
|
2930
|
+
if (!platform || !nativeId) return { success: false, error: "No active meeting agent found." };
|
|
2931
|
+
const base = (process.env.SVAMP_VEXA_API_URL || "").replace(/\/$/, "");
|
|
2932
|
+
const key = process.env.SVAMP_VEXA_API_KEY || "";
|
|
2933
|
+
try {
|
|
2934
|
+
const res = await fetch(`${base}/bots/${platform}/${nativeId}`, { method: "DELETE", headers: { "X-API-Key": key } });
|
|
2935
|
+
if (k) activeMeetingAgents.delete(k);
|
|
2936
|
+
return { success: res.ok };
|
|
2937
|
+
} catch (e) {
|
|
2938
|
+
return { success: false, error: e instanceof Error ? e.message : "leave failed" };
|
|
2939
|
+
}
|
|
2940
|
+
},
|
|
2941
|
+
// Drives the title-bar "WISE in a meeting" indicator (poll per session).
|
|
2942
|
+
wiseMeetingStatus: async (params) => {
|
|
2943
|
+
if (params?.sessionId) {
|
|
2944
|
+
const rec = activeMeetingAgents.get(params.sessionId);
|
|
2945
|
+
return { active: !!rec, meeting: rec || null };
|
|
2946
|
+
}
|
|
2947
|
+
return { active: activeMeetingAgents.size > 0, meetings: Array.from(activeMeetingAgents.values()) };
|
|
2948
|
+
},
|
|
2877
2949
|
// Cheap "subagent" text summary for the WISE voice agent's summarize_session
|
|
2878
2950
|
// tool. The browser gathers the (possibly long) text and asks a question; the
|
|
2879
2951
|
// call runs SERVER-SIDE with the machine's OpenAI key — never from the browser,
|
|
@@ -2978,7 +3050,7 @@ QUESTION: ${params.question || "Summarize this concisely."}` }
|
|
|
2978
3050
|
}
|
|
2979
3051
|
const deps = buildSessionDeps(rpc, { cwd, ownerEmail: owner });
|
|
2980
3052
|
const sender = { name: context?.user?.email || context?.user?.id || "user", kind: "user", verified: true };
|
|
2981
|
-
const { toolsForRole } = await import('./sideband
|
|
3053
|
+
const { toolsForRole } = await import('./sideband-Cg0Ttcuj.mjs');
|
|
2982
3054
|
const r2 = await runWiseAgent({ message: params.message, sender, config: { tools: toolsForRole(role2) }, deps, transport, model: resolved.model });
|
|
2983
3055
|
return fmt(r2);
|
|
2984
3056
|
}
|
|
@@ -3077,7 +3149,7 @@ QUESTION: ${params.question || "Summarize this concisely."}` }
|
|
|
3077
3149
|
if (r.error || !r.sender) return { error: r.error || "unauthorized" };
|
|
3078
3150
|
const callId = "call_" + Math.random().toString(16).slice(2, 12);
|
|
3079
3151
|
const rendered = renderMessage(c, { sender: r.sender, body: { message: kwargs.message }, callId });
|
|
3080
|
-
const { queryCore } = await import('./commands-
|
|
3152
|
+
const { queryCore } = await import('./commands-D7lgEFnK.mjs');
|
|
3081
3153
|
const timeout = c.reply?.timeout_sec || 120;
|
|
3082
3154
|
let result;
|
|
3083
3155
|
try {
|
|
@@ -11531,7 +11603,7 @@ async function startDaemon(options) {
|
|
|
11531
11603
|
saveExposedTunnels(list);
|
|
11532
11604
|
}
|
|
11533
11605
|
async function createExposedTunnel(spec) {
|
|
11534
|
-
const { FrpcTunnel } = await import('./frpc-
|
|
11606
|
+
const { FrpcTunnel } = await import('./frpc-DorJMSBi.mjs');
|
|
11535
11607
|
const tunnel = new FrpcTunnel({
|
|
11536
11608
|
name: spec.name,
|
|
11537
11609
|
ports: spec.ports,
|
|
@@ -11551,7 +11623,7 @@ async function startDaemon(options) {
|
|
|
11551
11623
|
return tunnel;
|
|
11552
11624
|
}
|
|
11553
11625
|
const tunnelRecreateState = /* @__PURE__ */ new Map();
|
|
11554
|
-
const { ServeManager } = await import('./serveManager-
|
|
11626
|
+
const { ServeManager } = await import('./serveManager-Cd7jyXHD.mjs');
|
|
11555
11627
|
const serveManager = new ServeManager(SVAMP_HOME, (msg) => logger.log(`[SERVE] ${msg}`), hyphaServerUrl);
|
|
11556
11628
|
ensureAutoInstalledSkills(logger).catch(() => {
|
|
11557
11629
|
});
|
|
@@ -54,7 +54,7 @@ async function handleServeCommand() {
|
|
|
54
54
|
}
|
|
55
55
|
}
|
|
56
56
|
async function serveAdd(args, machineId) {
|
|
57
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
57
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
58
58
|
const pos = positionalArgs(args);
|
|
59
59
|
const name = pos[0];
|
|
60
60
|
if (!name) {
|
|
@@ -93,7 +93,7 @@ async function serveAdd(args, machineId) {
|
|
|
93
93
|
}
|
|
94
94
|
}
|
|
95
95
|
async function serveApply(args, machineId) {
|
|
96
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
96
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
97
97
|
const fs = await import('fs');
|
|
98
98
|
const yaml = await import('yaml');
|
|
99
99
|
const file = positionalArgs(args)[0];
|
|
@@ -182,7 +182,7 @@ async function serveApply(args, machineId) {
|
|
|
182
182
|
}
|
|
183
183
|
}
|
|
184
184
|
async function serveRemove(args, machineId) {
|
|
185
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
185
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
186
186
|
const pos = positionalArgs(args);
|
|
187
187
|
const name = pos[0];
|
|
188
188
|
if (!name) {
|
|
@@ -202,7 +202,7 @@ async function serveRemove(args, machineId) {
|
|
|
202
202
|
}
|
|
203
203
|
}
|
|
204
204
|
async function serveList(args, machineId) {
|
|
205
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
205
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
206
206
|
const all = hasFlag(args, "--all", "-a");
|
|
207
207
|
const json = hasFlag(args, "--json");
|
|
208
208
|
const sessionId = getFlag(args, "--session");
|
|
@@ -235,7 +235,7 @@ async function serveList(args, machineId) {
|
|
|
235
235
|
}
|
|
236
236
|
}
|
|
237
237
|
async function serveInfo(machineId) {
|
|
238
|
-
const { connectAndGetMachine } = await import('./commands-
|
|
238
|
+
const { connectAndGetMachine } = await import('./commands-D7lgEFnK.mjs');
|
|
239
239
|
const { machine, server } = await connectAndGetMachine(machineId);
|
|
240
240
|
try {
|
|
241
241
|
const info = await machine.serveInfo();
|
|
@@ -4,7 +4,7 @@ import * as fs from 'fs';
|
|
|
4
4
|
import * as http from 'http';
|
|
5
5
|
import * as net from 'net';
|
|
6
6
|
import * as path from 'path';
|
|
7
|
-
import { k as getHyphaServerUrl, S as ServeAuth, l as hasCookieToken } from './run-
|
|
7
|
+
import { k as getHyphaServerUrl, S as ServeAuth, l as hasCookieToken } from './run-vPl2hvCU.mjs';
|
|
8
8
|
import 'os';
|
|
9
9
|
import 'fs/promises';
|
|
10
10
|
import 'url';
|
|
@@ -24,7 +24,14 @@ import 'node:fs/promises';
|
|
|
24
24
|
import 'node:util';
|
|
25
25
|
|
|
26
26
|
function generateLinkToken() {
|
|
27
|
-
return crypto.randomBytes(
|
|
27
|
+
return crypto.randomBytes(11).toString("hex");
|
|
28
|
+
}
|
|
29
|
+
const DNS_LABEL_MAX = 63;
|
|
30
|
+
function buildLinkSubdomain(subdomainSafe, linkToken) {
|
|
31
|
+
const prefix = "static-";
|
|
32
|
+
const room = Math.max(1, DNS_LABEL_MAX - prefix.length - 1 - linkToken.length);
|
|
33
|
+
const namePart = subdomainSafe.slice(0, room).replace(/-+$/, "") || "s";
|
|
34
|
+
return `${prefix}${namePart}-${linkToken}`;
|
|
28
35
|
}
|
|
29
36
|
function findFreePort() {
|
|
30
37
|
return new Promise((resolve, reject) => {
|
|
@@ -724,9 +731,9 @@ class ServeManager {
|
|
|
724
731
|
const subdomainSafe = mountName.toLowerCase().replace(/[^a-z0-9-]/g, "-");
|
|
725
732
|
const tunnelName = `static-${subdomainSafe}`;
|
|
726
733
|
const mount = this.mounts.get(mountName);
|
|
727
|
-
const subdomainOverride = mount?.access === "link" && mount.linkToken ? /* @__PURE__ */ new Map([[this.port,
|
|
734
|
+
const subdomainOverride = mount?.access === "link" && mount.linkToken ? /* @__PURE__ */ new Map([[this.port, buildLinkSubdomain(subdomainSafe, mount.linkToken)]]) : void 0;
|
|
728
735
|
try {
|
|
729
|
-
const { FrpcTunnel } = await import('./frpc-
|
|
736
|
+
const { FrpcTunnel } = await import('./frpc-DorJMSBi.mjs');
|
|
730
737
|
let tunnel;
|
|
731
738
|
tunnel = new FrpcTunnel({
|
|
732
739
|
name: tunnelName,
|
|
@@ -771,4 +778,4 @@ class ServeManager {
|
|
|
771
778
|
}
|
|
772
779
|
}
|
|
773
780
|
|
|
774
|
-
export { ServeManager };
|
|
781
|
+
export { ServeManager, buildLinkSubdomain };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { R as READ_ONLY_TOOLS, z as loadMachineContext, A as buildMachineInstructions, B as machineToolsForRole, C as buildMachineTools } from './run-
|
|
1
|
+
import { R as READ_ONLY_TOOLS, z as loadMachineContext, A as buildMachineInstructions, B as machineToolsForRole, C as buildMachineTools } from './run-vPl2hvCU.mjs';
|
|
2
2
|
import 'node:child_process';
|
|
3
3
|
import 'os';
|
|
4
4
|
import 'fs/promises';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "svamp-cli",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.141",
|
|
4
4
|
"description": "Svamp CLI — AI workspace daemon on Hypha Cloud",
|
|
5
5
|
"author": "Amun AI AB",
|
|
6
6
|
"license": "SEE LICENSE IN LICENSE",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
"scripts": {
|
|
21
21
|
"build": "rm -rf dist bin/skills && mkdir -p bin/skills && cp -r ../../skills/artifact bin/skills/artifact && cp -r ../../skills/loop bin/skills/loop && cp -r ../../skills/crew bin/skills/crew && tsc --noEmit && pkgroll",
|
|
22
22
|
"typecheck": "tsc --noEmit",
|
|
23
|
-
"test": "npx tsx test/test-context-window.mjs && npx tsx test/test-ratelimit-retry.mjs && npx tsx test/test-instance-config.mjs && npx tsx test/test-authorize.mjs && npx tsx test/test-normalize-allowed-user.mjs && npx tsx test/test-share-url.mjs && npx tsx test/test-update-sharing-normalization.mjs && npx tsx test/test-staged-homes-sweep.mjs && npx tsx test/test-session-helpers.mjs && npx tsx test/test-cli-routing.mjs && npx tsx test/test-security-context.mjs && npx tsx test/test-isolation-decision.mjs && npx tsx test/test-loop-activation.mjs && npx tsx test/test-message-helpers.mjs && npx tsx test/test-agent-config.mjs && npx tsx test/test-wrap-command.mjs && npx tsx test/test-credential-staging.mjs && npx tsx test/test-claude-auth.mjs && npx tsx test/test-output-formatters.mjs && npx tsx test/test-inbox-guard.mjs && npx tsx test/test-auto-topic.mjs && npx tsx test/test-project-info.mjs && npx tsx test/test-agent-types.mjs && npx tsx test/test-transport.mjs && npx tsx test/test-session-update-handlers.mjs && npx tsx test/test-session-scanner.mjs && npx tsx test/test-hypha-client.mjs && npx tsx test/test-hook-settings.mjs && npx tsx test/test-session-service-logic.mjs && npx tsx test/test-daemon-persistence.mjs && npx tsx test/test-detect-isolation.mjs && npx tsx test/test-machine-service-logic.mjs && npx tsx test/test-interactive-helpers.mjs && npx tsx test/test-codex-backend.mjs && npx tsx test/test-acp-backend.mjs && npx tsx test/test-acp-bridge.mjs && npx tsx test/test-hook-server.mjs && npx tsx test/test-session-commands.mjs && npx tsx test/test-interactive-console.mjs && npx tsx test/test-session-messages.mjs && npx tsx test/test-session-send-query.mjs && npx tsx test/test-skills.mjs && npx tsx test/test-agent-grouping.mjs && npx tsx test/test-machine-list-directory.mjs && npx tsx test/test-service-commands.mjs && npx tsx test/test-supervisor.mjs && npx tsx test/test-supervisor-lock.mjs && node test/test-supervisor-restart.mjs && npx tsx test/test-clear-detection.mjs && npx tsx test/test-session-consolidation.mjs && npx tsx test/test-inbox.mjs && npx tsx test/test-checklist.mjs && npx tsx test/test-checklist-cli.mjs && npx tsx test/test-short-id.mjs && npx tsx test/test-transcript-edit.mjs && npx tsx test/test-edit-history.mjs && npx tsx test/test-friendly-name.mjs && npx tsx test/test-session-rpc-dispatch.mjs && npx tsx test/test-sandbox-cli.mjs && npx tsx test/test-serve-manager.mjs && npx tsx test/test-serve-stability.mjs && npx tsx test/test-frpc-e2e.mjs --unit-only && npx tsx test/test-frpc-status.mjs && node test/pinnedClaudeCode.test.mjs && node test/fleet.test.mjs && npx tsx test/test-routine.mjs && npx tsx test/test-routine-rpc.mjs && npx tsx test/test-checklist-watchdog.mjs && npx tsx test/test-session-file.mjs && npx tsx test/test-channel-rpc.mjs && npx tsx test/test-wise-agent.mjs && npx tsx test/test-channel-agent.mjs && npx tsx test/test-channels-service.mjs && npx tsx test/test-channel-async-reply.mjs && npx tsx test/test-channel-binding.mjs && npx tsx test/test-channel-identity.mjs && npx tsx test/test-shared-session-identity.mjs && npx tsx test/test-wise-agent-auth.mjs && npx tsx test/test-channel-http.mjs && npx tsx test/test-wise-voice.mjs && npx tsx test/test-wise-headless.mjs && npx tsx test/test-wise-machine.mjs && npx tsx test/test-crew-merge.mjs",
|
|
23
|
+
"test": "npx tsx test/test-context-window.mjs && npx tsx test/test-ratelimit-retry.mjs && npx tsx test/test-instance-config.mjs && npx tsx test/test-authorize.mjs && npx tsx test/test-normalize-allowed-user.mjs && npx tsx test/test-share-url.mjs && npx tsx test/test-update-sharing-normalization.mjs && npx tsx test/test-staged-homes-sweep.mjs && npx tsx test/test-session-helpers.mjs && npx tsx test/test-cli-routing.mjs && npx tsx test/test-security-context.mjs && npx tsx test/test-isolation-decision.mjs && npx tsx test/test-loop-activation.mjs && npx tsx test/test-message-helpers.mjs && npx tsx test/test-agent-config.mjs && npx tsx test/test-wrap-command.mjs && npx tsx test/test-credential-staging.mjs && npx tsx test/test-claude-auth.mjs && npx tsx test/test-output-formatters.mjs && npx tsx test/test-inbox-guard.mjs && npx tsx test/test-auto-topic.mjs && npx tsx test/test-project-info.mjs && npx tsx test/test-agent-types.mjs && npx tsx test/test-transport.mjs && npx tsx test/test-session-update-handlers.mjs && npx tsx test/test-session-scanner.mjs && npx tsx test/test-hypha-client.mjs && npx tsx test/test-hook-settings.mjs && npx tsx test/test-session-service-logic.mjs && npx tsx test/test-daemon-persistence.mjs && npx tsx test/test-detect-isolation.mjs && npx tsx test/test-machine-service-logic.mjs && npx tsx test/test-interactive-helpers.mjs && npx tsx test/test-codex-backend.mjs && npx tsx test/test-acp-backend.mjs && npx tsx test/test-acp-bridge.mjs && npx tsx test/test-hook-server.mjs && npx tsx test/test-session-commands.mjs && npx tsx test/test-interactive-console.mjs && npx tsx test/test-session-messages.mjs && npx tsx test/test-session-send-query.mjs && npx tsx test/test-skills.mjs && npx tsx test/test-agent-grouping.mjs && npx tsx test/test-machine-list-directory.mjs && npx tsx test/test-service-commands.mjs && npx tsx test/test-supervisor.mjs && npx tsx test/test-supervisor-lock.mjs && node test/test-supervisor-restart.mjs && npx tsx test/test-clear-detection.mjs && npx tsx test/test-session-consolidation.mjs && npx tsx test/test-inbox.mjs && npx tsx test/test-checklist.mjs && npx tsx test/test-checklist-cli.mjs && npx tsx test/test-serve-link-subdomain.mjs && npx tsx test/test-short-id.mjs && npx tsx test/test-transcript-edit.mjs && npx tsx test/test-edit-history.mjs && npx tsx test/test-friendly-name.mjs && npx tsx test/test-session-rpc-dispatch.mjs && npx tsx test/test-sandbox-cli.mjs && npx tsx test/test-serve-manager.mjs && npx tsx test/test-serve-stability.mjs && npx tsx test/test-frpc-e2e.mjs --unit-only && npx tsx test/test-frpc-status.mjs && node test/pinnedClaudeCode.test.mjs && node test/fleet.test.mjs && npx tsx test/test-routine.mjs && npx tsx test/test-routine-rpc.mjs && npx tsx test/test-checklist-watchdog.mjs && npx tsx test/test-session-file.mjs && npx tsx test/test-channel-rpc.mjs && npx tsx test/test-wise-agent.mjs && npx tsx test/test-channel-agent.mjs && npx tsx test/test-channels-service.mjs && npx tsx test/test-channel-async-reply.mjs && npx tsx test/test-channel-binding.mjs && npx tsx test/test-channel-identity.mjs && npx tsx test/test-shared-session-identity.mjs && npx tsx test/test-wise-agent-auth.mjs && npx tsx test/test-channel-http.mjs && npx tsx test/test-wise-voice.mjs && npx tsx test/test-wise-headless.mjs && npx tsx test/test-wise-machine.mjs && npx tsx test/test-crew-merge.mjs",
|
|
24
24
|
"test:hypha": "node --no-warnings test/test-hypha-service.mjs",
|
|
25
25
|
"dev": "tsx src/cli.ts",
|
|
26
26
|
"dev:daemon": "tsx src/cli.ts daemon start-sync",
|