@agentmeshhq/agent 0.4.0 → 0.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/dist/__tests__/bootstrap.test.d.ts +1 -0
  2. package/dist/__tests__/bootstrap.test.js +39 -0
  3. package/dist/__tests__/bootstrap.test.js.map +1 -0
  4. package/dist/__tests__/claims.integration.test.d.ts +1 -0
  5. package/dist/__tests__/claims.integration.test.js +128 -0
  6. package/dist/__tests__/claims.integration.test.js.map +1 -0
  7. package/dist/__tests__/context-template.test.js +15 -0
  8. package/dist/__tests__/context-template.test.js.map +1 -1
  9. package/dist/__tests__/handoff-sla.test.d.ts +1 -0
  10. package/dist/__tests__/handoff-sla.test.js +29 -0
  11. package/dist/__tests__/handoff-sla.test.js.map +1 -0
  12. package/dist/__tests__/handoff.integration.test.d.ts +1 -0
  13. package/dist/__tests__/handoff.integration.test.js +77 -0
  14. package/dist/__tests__/handoff.integration.test.js.map +1 -0
  15. package/dist/__tests__/injector.test.js +31 -2
  16. package/dist/__tests__/injector.test.js.map +1 -1
  17. package/dist/__tests__/registry.claims.test.d.ts +1 -0
  18. package/dist/__tests__/registry.claims.test.js +70 -0
  19. package/dist/__tests__/registry.claims.test.js.map +1 -0
  20. package/dist/__tests__/registry.retry.test.d.ts +1 -0
  21. package/dist/__tests__/registry.retry.test.js +33 -0
  22. package/dist/__tests__/registry.retry.test.js.map +1 -0
  23. package/dist/__tests__/status.test.d.ts +1 -0
  24. package/dist/__tests__/status.test.js +55 -0
  25. package/dist/__tests__/status.test.js.map +1 -0
  26. package/dist/__tests__/worker.test.d.ts +1 -0
  27. package/dist/__tests__/worker.test.js +51 -0
  28. package/dist/__tests__/worker.test.js.map +1 -0
  29. package/dist/cli/autopilot.d.ts +17 -0
  30. package/dist/cli/autopilot.js +20 -0
  31. package/dist/cli/autopilot.js.map +1 -0
  32. package/dist/cli/claims.d.ts +18 -0
  33. package/dist/cli/claims.js +133 -0
  34. package/dist/cli/claims.js.map +1 -0
  35. package/dist/cli/handoff.d.ts +22 -0
  36. package/dist/cli/handoff.js +147 -0
  37. package/dist/cli/handoff.js.map +1 -0
  38. package/dist/cli/index.js +211 -2
  39. package/dist/cli/index.js.map +1 -1
  40. package/dist/cli/start.d.ts +2 -0
  41. package/dist/cli/start.js +3 -0
  42. package/dist/cli/start.js.map +1 -1
  43. package/dist/cli/status.d.ts +14 -1
  44. package/dist/cli/status.js +46 -1
  45. package/dist/cli/status.js.map +1 -1
  46. package/dist/cli/worker.d.ts +2 -0
  47. package/dist/cli/worker.js +52 -0
  48. package/dist/cli/worker.js.map +1 -0
  49. package/dist/config/schema.d.ts +12 -0
  50. package/dist/core/daemon/bootstrap.d.ts +2 -0
  51. package/dist/core/daemon/bootstrap.js +10 -1
  52. package/dist/core/daemon/bootstrap.js.map +1 -1
  53. package/dist/core/daemon/context-template.d.ts +7 -2
  54. package/dist/core/daemon/context-template.js +18 -11
  55. package/dist/core/daemon/context-template.js.map +1 -1
  56. package/dist/core/daemon/workspace.d.ts +5 -0
  57. package/dist/core/daemon/workspace.js +47 -7
  58. package/dist/core/daemon/workspace.js.map +1 -1
  59. package/dist/core/daemon.d.ts +19 -0
  60. package/dist/core/daemon.js +286 -20
  61. package/dist/core/daemon.js.map +1 -1
  62. package/dist/core/handoff-sla.d.ts +6 -0
  63. package/dist/core/handoff-sla.js +29 -0
  64. package/dist/core/handoff-sla.js.map +1 -0
  65. package/dist/core/injector.js +2 -2
  66. package/dist/core/injector.js.map +1 -1
  67. package/dist/core/registry.d.ts +47 -0
  68. package/dist/core/registry.js +105 -0
  69. package/dist/core/registry.js.map +1 -1
  70. package/dist/core/tmux-runtime.js +5 -2
  71. package/dist/core/tmux-runtime.js.map +1 -1
  72. package/package.json +12 -11
  73. package/LICENSE +0 -21
@@ -0,0 +1,51 @@
1
+ import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
2
+ import { pauseWorkerAutomation, resumeWorkerAutomation } from "../cli/worker.js";
3
+ const mocks = vi.hoisted(() => ({
4
+ getAgentState: vi.fn(),
5
+ loadConfig: vi.fn(),
6
+ updateAgentInState: vi.fn(),
7
+ getSessionName: vi.fn(),
8
+ sessionExists: vi.fn(),
9
+ sendKeys: vi.fn(),
10
+ }));
11
+ vi.mock("../config/loader.js", () => ({
12
+ getAgentState: mocks.getAgentState,
13
+ loadConfig: mocks.loadConfig,
14
+ updateAgentInState: mocks.updateAgentInState,
15
+ }));
16
+ vi.mock("../core/tmux.js", () => ({
17
+ getSessionName: mocks.getSessionName,
18
+ sessionExists: mocks.sessionExists,
19
+ sendKeys: mocks.sendKeys,
20
+ }));
21
+ describe("worker intervention controls", () => {
22
+ beforeEach(() => {
23
+ vi.clearAllMocks();
24
+ mocks.getSessionName.mockReturnValue("agentmesh-demo");
25
+ mocks.getAgentState.mockReturnValue({ name: "demo", agentId: "agt_demo", token: "tok" });
26
+ mocks.loadConfig.mockReturnValue({ workspace: "agentmesh", hubUrl: "https://agentmeshhq.dev" });
27
+ mocks.sessionExists.mockReturnValue(true);
28
+ vi.stubGlobal("fetch", vi.fn().mockResolvedValue({
29
+ ok: true,
30
+ }));
31
+ });
32
+ afterEach(() => {
33
+ vi.unstubAllGlobals();
34
+ });
35
+ it("pauses automation and notifies local tmux session", async () => {
36
+ await pauseWorkerAutomation("demo");
37
+ expect(mocks.updateAgentInState).toHaveBeenCalledWith("demo", { automationPaused: true });
38
+ expect(mocks.sendKeys).toHaveBeenCalledTimes(1);
39
+ });
40
+ it("resumes automation and notifies local tmux session", async () => {
41
+ await resumeWorkerAutomation("demo");
42
+ expect(mocks.updateAgentInState).toHaveBeenCalledWith("demo", { automationPaused: false });
43
+ expect(mocks.sendKeys).toHaveBeenCalledTimes(1);
44
+ });
45
+ it("throws when agent does not exist", async () => {
46
+ mocks.getAgentState.mockReturnValue(undefined);
47
+ await expect(pauseWorkerAutomation("missing")).rejects.toThrow('Agent "missing" not found.');
48
+ await expect(resumeWorkerAutomation("missing")).rejects.toThrow('Agent "missing" not found.');
49
+ });
50
+ });
51
+ //# sourceMappingURL=worker.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"worker.test.js","sourceRoot":"","sources":["../../src/__tests__/worker.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ type AutopilotRunOptions = {
2
+ name: string;
3
+ command?: string;
4
+ workdir?: string;
5
+ model?: string;
6
+ restoreContext?: boolean;
7
+ autoSetup?: boolean;
8
+ project?: string;
9
+ role?: string;
10
+ noAutoAcceptHandoffs?: boolean;
11
+ };
12
+ /**
13
+ * Compatibility entrypoint for legacy `mesh autopilot`.
14
+ * Internally routes to the canonical `agentmesh start --worker` runtime path.
15
+ */
16
+ export declare function runAutopilot(options: AutopilotRunOptions): Promise<void>;
17
+ export {};
@@ -0,0 +1,20 @@
1
+ import { start } from "./start.js";
2
+ /**
3
+ * Compatibility entrypoint for legacy `mesh autopilot`.
4
+ * Internally routes to the canonical `agentmesh start --worker` runtime path.
5
+ */
6
+ export async function runAutopilot(options) {
7
+ await start({
8
+ name: options.name,
9
+ command: options.command,
10
+ workdir: options.workdir,
11
+ model: options.model,
12
+ restoreContext: options.restoreContext,
13
+ worker: true,
14
+ autoSetup: options.autoSetup,
15
+ project: options.project,
16
+ role: options.role,
17
+ autoAcceptHandoffs: !options.noAutoAcceptHandoffs,
18
+ });
19
+ }
20
+ //# sourceMappingURL=autopilot.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"autopilot.js","sourceRoot":"","sources":["../../src/cli/autopilot.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAcnC;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAA4B;IAC7D,MAAM,KAAK,CAAC;QACV,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,cAAc,EAAE,OAAO,CAAC,cAAc;QACtC,MAAM,EAAE,IAAI;QACZ,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,kBAAkB,EAAE,CAAC,OAAO,CAAC,oBAAoB;KAClD,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,18 @@
1
+ type ClaimCreateOptions = {
2
+ name?: string;
3
+ scope: string;
4
+ paths: string[];
5
+ ttlSeconds?: number;
6
+ };
7
+ type ClaimListOptions = {
8
+ name?: string;
9
+ json?: boolean;
10
+ status?: string;
11
+ };
12
+ type ClaimReleaseOptions = {
13
+ name?: string;
14
+ };
15
+ export declare function createClaim(options: ClaimCreateOptions): Promise<void>;
16
+ export declare function listClaims(options: ClaimListOptions): Promise<void>;
17
+ export declare function releaseClaim(claimId: string, options: ClaimReleaseOptions): Promise<void>;
18
+ export {};
@@ -0,0 +1,133 @@
1
+ import pc from "picocolors";
2
+ import { loadConfig, loadState } from "../config/loader.js";
3
+ function resolveAuthContext(agentName) {
4
+ const config = loadConfig();
5
+ if (!config) {
6
+ throw new Error("No config found. Run 'agentmesh init' first.");
7
+ }
8
+ const envToken = process.env.AGENT_TOKEN;
9
+ const envAgentId = process.env.AGENTMESH_AGENT_ID;
10
+ if (envToken && !agentName) {
11
+ return {
12
+ hubUrl: config.hubUrl,
13
+ workspace: config.workspace,
14
+ token: envToken,
15
+ agentId: envAgentId,
16
+ };
17
+ }
18
+ const state = loadState();
19
+ let agent = agentName ? state.agents.find((a) => a.name === agentName) : undefined;
20
+ if (!agent && !agentName && envAgentId) {
21
+ agent = state.agents.find((a) => a.agentId === envAgentId);
22
+ }
23
+ if (!agent && !agentName) {
24
+ if (state.agents.length === 1) {
25
+ agent = state.agents[0];
26
+ }
27
+ else if (state.agents.length > 1) {
28
+ throw new Error("Multiple agents found. Pass --name to select which agent token to use.");
29
+ }
30
+ }
31
+ if (!agent) {
32
+ if (agentName) {
33
+ throw new Error(`Agent "${agentName}" not found.`);
34
+ }
35
+ throw new Error("No agent token available. Start an agent or run inside an agent session.");
36
+ }
37
+ if (!agent.token) {
38
+ throw new Error(`No token found for agent "${agent.name}". Run 'agentmesh token refresh --name ${agent.name}'.`);
39
+ }
40
+ return {
41
+ hubUrl: config.hubUrl,
42
+ workspace: config.workspace,
43
+ token: agent.token,
44
+ agentName: agent.name,
45
+ agentId: agent.agentId,
46
+ };
47
+ }
48
+ async function meshRequest(context, path, init = {}) {
49
+ const response = await fetch(`${context.hubUrl}${path}`, {
50
+ ...init,
51
+ headers: {
52
+ Authorization: `Bearer ${context.token}`,
53
+ ...(init.headers ?? {}),
54
+ },
55
+ });
56
+ if (!response.ok) {
57
+ const text = await response.text();
58
+ throw new Error(`Hub request failed (${response.status}): ${text}`);
59
+ }
60
+ if (response.status === 204) {
61
+ return {};
62
+ }
63
+ return (await response.json());
64
+ }
65
+ function formatDate(isoDate) {
66
+ if (!isoDate) {
67
+ return "-";
68
+ }
69
+ const date = new Date(isoDate);
70
+ if (Number.isNaN(date.getTime())) {
71
+ return isoDate;
72
+ }
73
+ return date.toISOString().replace("T", " ").slice(0, 19);
74
+ }
75
+ function parsePathPatterns(inputPaths) {
76
+ return inputPaths
77
+ .flatMap((value) => value.split(","))
78
+ .map((value) => value.trim())
79
+ .filter(Boolean);
80
+ }
81
+ export async function createClaim(options) {
82
+ const context = resolveAuthContext(options.name);
83
+ const paths = parsePathPatterns(options.paths);
84
+ if (paths.length === 0) {
85
+ throw new Error("At least one path pattern is required.");
86
+ }
87
+ if (options.ttlSeconds !== undefined &&
88
+ (!Number.isInteger(options.ttlSeconds) || options.ttlSeconds < 30 || options.ttlSeconds > 86400)) {
89
+ throw new Error("ttl-seconds must be an integer between 30 and 86400.");
90
+ }
91
+ const response = await meshRequest(context, `/api/v1/workspaces/${context.workspace}/claims`, {
92
+ method: "POST",
93
+ headers: { "Content-Type": "application/json" },
94
+ body: JSON.stringify({
95
+ scope: options.scope,
96
+ paths,
97
+ ttl_seconds: options.ttlSeconds,
98
+ }),
99
+ });
100
+ console.log(pc.green(`Claim ${response.claim_id} created.`));
101
+ }
102
+ export async function listClaims(options) {
103
+ const context = resolveAuthContext(options.name);
104
+ const response = await meshRequest(context, `/api/v1/workspaces/${context.workspace}/claims`);
105
+ const claims = response.data ?? [];
106
+ const filtered = options.status
107
+ ? claims.filter((claim) => claim.status === options.status)
108
+ : claims;
109
+ if (options.json) {
110
+ console.log(JSON.stringify({ data: filtered }, null, 2));
111
+ return;
112
+ }
113
+ if (filtered.length === 0) {
114
+ const suffix = options.status ? ` (status=${options.status})` : "";
115
+ console.log(pc.dim(`No claims found${suffix}.`));
116
+ return;
117
+ }
118
+ console.log(pc.bold(`Claims (${filtered.length})`));
119
+ console.log(`${"ID".padEnd(18)} ${"STATUS".padEnd(14)} ${"AGENT".padEnd(24)} ${"SCOPE".padEnd(26)} ${"PATHS".padEnd(28)} EXPIRES`);
120
+ console.log("-".repeat(130));
121
+ for (const claim of filtered) {
122
+ const claimPaths = claim.paths.join(", ");
123
+ console.log(`${claim.claim_id.slice(0, 18).padEnd(18)} ${claim.status.padEnd(14)} ${claim.agent_id.slice(0, 24).padEnd(24)} ${claim.scope.slice(0, 26).padEnd(26)} ${claimPaths.slice(0, 28).padEnd(28)} ${formatDate(claim.expires_at)}`);
124
+ }
125
+ }
126
+ export async function releaseClaim(claimId, options) {
127
+ const context = resolveAuthContext(options.name);
128
+ await meshRequest(context, `/api/v1/claims/${claimId}/release`, {
129
+ method: "POST",
130
+ });
131
+ console.log(pc.green(`Claim ${claimId} released.`));
132
+ }
133
+ //# sourceMappingURL=claims.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claims.js","sourceRoot":"","sources":["../../src/cli/claims.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ type HandoffStatus = "accepted" | "rejected";
2
+ type InboxOptions = {
3
+ name?: string;
4
+ type?: string;
5
+ includeAll?: boolean;
6
+ json?: boolean;
7
+ };
8
+ type CompleteOptions = {
9
+ name?: string;
10
+ notes?: string;
11
+ };
12
+ type ReassignOptions = {
13
+ name?: string;
14
+ toAgentId: string;
15
+ scope?: string;
16
+ reason?: string;
17
+ };
18
+ export declare function inbox(options: InboxOptions): Promise<void>;
19
+ export declare function updateHandoffStatus(handoffId: string, status: HandoffStatus, name?: string): Promise<void>;
20
+ export declare function completeHandoff(handoffId: string, options: CompleteOptions): Promise<void>;
21
+ export declare function reassignHandoff(handoffId: string, options: ReassignOptions): Promise<void>;
22
+ export {};
@@ -0,0 +1,147 @@
1
+ import pc from "picocolors";
2
+ import { loadConfig, loadState } from "../config/loader.js";
3
+ function resolveAuthContext(agentName) {
4
+ const config = loadConfig();
5
+ if (!config) {
6
+ throw new Error("No config found. Run 'agentmesh init' first.");
7
+ }
8
+ const envToken = process.env.AGENT_TOKEN;
9
+ const envAgentId = process.env.AGENTMESH_AGENT_ID;
10
+ if (envToken && !agentName) {
11
+ return {
12
+ hubUrl: config.hubUrl,
13
+ workspace: config.workspace,
14
+ token: envToken,
15
+ agentId: envAgentId,
16
+ };
17
+ }
18
+ const state = loadState();
19
+ let agent = agentName ? state.agents.find((a) => a.name === agentName) : undefined;
20
+ if (!agent && !agentName && envAgentId) {
21
+ agent = state.agents.find((a) => a.agentId === envAgentId);
22
+ }
23
+ if (!agent && !agentName) {
24
+ if (state.agents.length === 1) {
25
+ agent = state.agents[0];
26
+ }
27
+ else if (state.agents.length > 1) {
28
+ throw new Error("Multiple agents found. Pass --name to select which agent token to use.");
29
+ }
30
+ }
31
+ if (!agent) {
32
+ if (agentName) {
33
+ throw new Error(`Agent "${agentName}" not found.`);
34
+ }
35
+ throw new Error("No agent token available. Start an agent or run inside an agent session.");
36
+ }
37
+ if (!agent.token) {
38
+ throw new Error(`No token found for agent "${agent.name}". Run 'agentmesh token refresh --name ${agent.name}'.`);
39
+ }
40
+ return {
41
+ hubUrl: config.hubUrl,
42
+ workspace: config.workspace,
43
+ token: agent.token,
44
+ agentName: agent.name,
45
+ agentId: agent.agentId,
46
+ };
47
+ }
48
+ async function meshRequest(context, path, init = {}) {
49
+ const response = await fetch(`${context.hubUrl}${path}`, {
50
+ ...init,
51
+ headers: {
52
+ Authorization: `Bearer ${context.token}`,
53
+ ...(init.headers ?? {}),
54
+ },
55
+ });
56
+ if (!response.ok) {
57
+ const text = await response.text();
58
+ throw new Error(`Hub request failed (${response.status}): ${text}`);
59
+ }
60
+ if (response.status === 204) {
61
+ return {};
62
+ }
63
+ return (await response.json());
64
+ }
65
+ function formatDate(isoDate) {
66
+ const date = new Date(isoDate);
67
+ if (Number.isNaN(date.getTime())) {
68
+ return isoDate;
69
+ }
70
+ return date.toISOString().replace("T", " ").slice(0, 19);
71
+ }
72
+ export async function inbox(options) {
73
+ const context = resolveAuthContext(options.name);
74
+ const type = options.type || "handoff";
75
+ const filter = options.includeAll ? undefined : "pending";
76
+ const params = new URLSearchParams();
77
+ if (type)
78
+ params.set("type", type);
79
+ if (filter)
80
+ params.set("filter", filter);
81
+ const query = params.toString();
82
+ const path = `/api/v1/workspaces/${context.workspace}/inbox${query ? `?${query}` : ""}`;
83
+ const response = await meshRequest(context, path);
84
+ const items = response.data ?? [];
85
+ if (options.json) {
86
+ console.log(JSON.stringify({ items, meta: response.meta ?? {} }, null, 2));
87
+ return;
88
+ }
89
+ if (items.length === 0) {
90
+ console.log(pc.dim(`No inbox items found (type=${type}${filter ? `, filter=${filter}` : ""}).`));
91
+ return;
92
+ }
93
+ console.log(pc.bold(`Inbox (${items.length})`));
94
+ console.log(`${"ID".padEnd(18)} ${"TYPE".padEnd(10)} ${"STATUS".padEnd(10)} ${"FROM".padEnd(24)} ${"SCOPE".padEnd(34)} CREATED`);
95
+ console.log("-".repeat(120));
96
+ for (const item of items) {
97
+ const from = item.from_agent_id ?? "-";
98
+ const scope = item.scope ?? item.reason ?? "-";
99
+ console.log(`${item.id.slice(0, 18).padEnd(18)} ${item.type.padEnd(10)} ${item.status.padEnd(10)} ${from.slice(0, 24).padEnd(24)} ${scope.slice(0, 34).padEnd(34)} ${formatDate(item.created_at)}`);
100
+ }
101
+ }
102
+ export async function updateHandoffStatus(handoffId, status, name) {
103
+ const context = resolveAuthContext(name);
104
+ await meshRequest(context, `/api/v1/workspaces/${context.workspace}/handoffs/${handoffId}`, {
105
+ method: "PATCH",
106
+ headers: { "Content-Type": "application/json" },
107
+ body: JSON.stringify({ status }),
108
+ });
109
+ console.log(pc.green(`Handoff ${handoffId} marked as ${status}.`));
110
+ }
111
+ export async function completeHandoff(handoffId, options) {
112
+ const context = resolveAuthContext(options.name);
113
+ await meshRequest(context, `/api/v1/workspaces/${context.workspace}/handoffs/${handoffId}/complete`, {
114
+ method: "POST",
115
+ headers: { "Content-Type": "application/json" },
116
+ body: JSON.stringify({ notes: options.notes }),
117
+ });
118
+ console.log(pc.green(`Handoff ${handoffId} marked as completed.`));
119
+ }
120
+ export async function reassignHandoff(handoffId, options) {
121
+ const context = resolveAuthContext(options.name);
122
+ const current = await meshRequest(context, `/api/v1/workspaces/${context.workspace}/handoffs/${handoffId}`);
123
+ const scope = options.scope ?? current.scope ?? `Reassigned from ${handoffId}`;
124
+ const reason = options.reason ??
125
+ `Reassigned by ${context.agentName ?? context.agentId ?? "po"} from ${current.to_agent_id ?? "unknown"}`;
126
+ await meshRequest(context, `/api/v1/workspaces/${context.workspace}/handoffs`, {
127
+ method: "POST",
128
+ headers: { "Content-Type": "application/json" },
129
+ body: JSON.stringify({
130
+ to_agent_id: options.toAgentId,
131
+ scope,
132
+ reason,
133
+ metadata: {
134
+ type: "reassignment",
135
+ source_handoff_id: handoffId,
136
+ },
137
+ }),
138
+ });
139
+ // Best effort: close the previous handoff by rejecting it from current actor context.
140
+ await meshRequest(context, `/api/v1/workspaces/${context.workspace}/handoffs/${handoffId}`, {
141
+ method: "PATCH",
142
+ headers: { "Content-Type": "application/json" },
143
+ body: JSON.stringify({ status: "rejected" }),
144
+ });
145
+ console.log(pc.green(`Handoff ${handoffId} reassigned to ${options.toAgentId}.`));
146
+ }
147
+ //# sourceMappingURL=handoff.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handoff.js","sourceRoot":"","sources":["../../src/cli/handoff.ts"],"names":[],"mappings":"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"}