mnemosyne-core 2.0.3 → 2.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/README.md +42 -25
  2. package/dist/{Store-BtdYuiUx.d.mts → Store-BJ8b6xbs.d.mts} +2 -0
  3. package/dist/{Store-BtdYuiUx.d.ts → Store-BJ8b6xbs.d.ts} +2 -0
  4. package/dist/cli/index.js +387 -5744
  5. package/dist/cli/index.js.map +1 -1
  6. package/dist/cli/index.mjs +387 -5744
  7. package/dist/cli/index.mjs.map +1 -1
  8. package/dist/{index-yTOihMUk.d.mts → index-2AoCh09i.d.mts} +1 -1
  9. package/dist/{index-B2oTMNlL.d.ts → index-BZrUZX8Z.d.ts} +1 -1
  10. package/dist/{index-B8PTQKy9.d.mts → index-CHbW0NJZ.d.mts} +1 -1
  11. package/dist/{index-DWk78ifo.d.ts → index-CfqixdlW.d.ts} +1 -1
  12. package/dist/index.d.mts +4 -4
  13. package/dist/index.d.ts +4 -4
  14. package/dist/index.js +281 -5726
  15. package/dist/index.js.map +1 -1
  16. package/dist/index.mjs +281 -5726
  17. package/dist/index.mjs.map +1 -1
  18. package/dist/mcp/index.d.mts +2 -2
  19. package/dist/mcp/index.d.ts +2 -2
  20. package/dist/mcp/index.js +1 -1
  21. package/dist/mcp/index.js.map +1 -1
  22. package/dist/mcp/index.mjs +1 -1
  23. package/dist/mcp/index.mjs.map +1 -1
  24. package/dist/sdk/index.d.mts +144 -41
  25. package/dist/sdk/index.d.ts +144 -41
  26. package/dist/sdk/index.js +92 -34
  27. package/dist/sdk/index.js.map +1 -1
  28. package/dist/sdk/index.mjs +92 -34
  29. package/dist/sdk/index.mjs.map +1 -1
  30. package/dist/server/api.d.mts +1 -1
  31. package/dist/server/api.d.ts +1 -1
  32. package/dist/server/api.js +205 -160
  33. package/dist/server/api.js.map +1 -1
  34. package/dist/server/api.mjs +205 -160
  35. package/dist/server/api.mjs.map +1 -1
  36. package/dist/server/index.d.mts +2 -2
  37. package/dist/server/index.d.ts +2 -2
  38. package/dist/server/index.js +245 -5694
  39. package/dist/server/index.js.map +1 -1
  40. package/dist/server/index.mjs +245 -5694
  41. package/dist/server/index.mjs.map +1 -1
  42. package/dist/server/websocket.d.mts +1 -1
  43. package/dist/server/websocket.d.ts +1 -1
  44. package/dist/ws/index.d.mts +1 -1
  45. package/dist/ws/index.d.ts +1 -1
  46. package/package.json +1 -1
  47. package/dist/sharp-win32-x64-CXV3GA3G.node +0 -0
@@ -8,8 +8,9 @@ var MnemosyneClient = class {
8
8
  this.apiKey = options.apiKey;
9
9
  this.timeout = options.timeout || 3e4;
10
10
  }
11
- async request(method, path, body) {
12
- const url = `${this.baseUrl}${path}`;
11
+ async request(method, path, body, query) {
12
+ const qs = query ? "?" + Object.entries(query).filter(([, v]) => v !== void 0).map(([k, v]) => `${encodeURIComponent(k)}=${encodeURIComponent(String(v))}`).join("&") : "";
13
+ const url = `${this.baseUrl}${path}${qs}`;
13
14
  const controller = new AbortController();
14
15
  const timer = setTimeout(() => controller.abort(), this.timeout);
15
16
  try {
@@ -17,7 +18,7 @@ var MnemosyneClient = class {
17
18
  Accept: "application/json",
18
19
  "Content-Type": "application/json"
19
20
  };
20
- if (this.apiKey) headers["X-API-Key"] = this.apiKey;
21
+ if (this.apiKey) headers["Authorization"] = `Bearer ${this.apiKey}`;
21
22
  const res = await fetch(url, {
22
23
  method,
23
24
  headers,
@@ -25,8 +26,14 @@ var MnemosyneClient = class {
25
26
  signal: controller.signal
26
27
  });
27
28
  if (!res.ok) {
28
- const text = await res.text().catch(() => "");
29
- throw new Error(`HTTP ${res.status}: ${text || res.statusText}`);
29
+ let detail = "";
30
+ try {
31
+ const errJson = await res.json();
32
+ detail = errJson.error || JSON.stringify(errJson);
33
+ } catch {
34
+ detail = await res.text().catch(() => res.statusText);
35
+ }
36
+ throw new Error(`HTTP ${res.status} on ${method} ${path}: ${detail || res.statusText}`);
30
37
  }
31
38
  return await res.json();
32
39
  } finally {
@@ -35,79 +42,130 @@ var MnemosyneClient = class {
35
42
  }
36
43
  // ── Health ─────────────────────────────────────────
37
44
  async health() {
38
- return this.request("GET", "/health");
45
+ return this.request("GET", "/api/v1/health");
39
46
  }
40
47
  // ── Projects ───────────────────────────────────────
41
48
  async listProjects() {
42
- return this.request("GET", "/projects");
49
+ const res = await this.request("GET", "/api/v1/projects");
50
+ return res.projects;
43
51
  }
44
52
  async getProject(id) {
45
- return this.request("GET", `/projects/${id}`);
53
+ const res = await this.request("GET", `/api/v1/projects/${id}`);
54
+ return res.project;
46
55
  }
47
56
  async createProject(data) {
48
- return this.request("POST", "/projects", data);
57
+ const res = await this.request("POST", "/api/v1/projects", data);
58
+ return res.project;
49
59
  }
50
60
  async deleteProject(id) {
51
- await this.request("DELETE", `/projects/${id}`);
61
+ await this.request("DELETE", `/api/v1/projects/${id}`);
52
62
  }
53
63
  // ── Atoms ──────────────────────────────────────────
54
64
  async listAtoms(projectId) {
55
- const qs = projectId ? `?project_id=${projectId}` : "";
56
- return this.request("GET", `/atoms${qs}`);
65
+ const res = await this.request("GET", "/api/v1/atoms", void 0, { project_id: projectId });
66
+ return res.atoms;
57
67
  }
58
68
  async getAtom(id) {
59
- return this.request("GET", `/atoms/${id}`);
69
+ const res = await this.request("GET", `/api/v1/atoms/${id}`);
70
+ return res.atom;
60
71
  }
61
72
  async createAtom(data) {
62
- return this.request("POST", "/atoms", data);
73
+ const res = await this.request("POST", "/api/v1/atoms", data);
74
+ return res.atom;
63
75
  }
64
76
  async updateAtom(id, data) {
65
- return this.request("PUT", `/atoms/${id}`, data);
77
+ const res = await this.request("PATCH", `/api/v1/atoms/${id}`, data);
78
+ return res.atom;
66
79
  }
67
80
  async deleteAtom(id) {
68
- await this.request("DELETE", `/atoms/${id}`);
81
+ await this.request("DELETE", `/api/v1/atoms/${id}`);
69
82
  }
70
83
  // ── Blocks ─────────────────────────────────────────
71
84
  async getBlocks(atomId) {
72
- return this.request("GET", `/atoms/${atomId}/blocks`);
85
+ const res = await this.request("GET", `/api/v1/atoms/${atomId}`, void 0, { fields: "blocks" });
86
+ return res.blocks || [];
73
87
  }
74
88
  async createBlock(atomId, data) {
75
- return this.request("POST", `/atoms/${atomId}/blocks`, data);
89
+ const res = await this.request("POST", `/api/v1/atoms/${atomId}/blocks`, data);
90
+ return res.block;
91
+ }
92
+ async updateBlock(id, data) {
93
+ const res = await this.request("PATCH", `/api/v1/blocks/${id}`, data);
94
+ return res.block;
95
+ }
96
+ async deleteBlock(id) {
97
+ await this.request("DELETE", `/api/v1/blocks/${id}`);
76
98
  }
77
99
  // ── Bonds ──────────────────────────────────────────
78
- async listBonds() {
79
- return this.request("GET", "/bonds");
100
+ async listBonds(atomId) {
101
+ if (atomId) {
102
+ const res = await this.request("GET", `/api/v1/atoms/${atomId}/bonds`);
103
+ return [...res.outgoing, ...res.incoming];
104
+ }
105
+ return this.request("GET", "/api/v1/bonds");
80
106
  }
81
- async createBond(data) {
82
- return this.request("POST", "/bonds", data);
107
+ async createBond(atomId, data) {
108
+ const res = await this.request("POST", `/api/v1/atoms/${atomId}/bonds`, data);
109
+ return res.bond;
83
110
  }
84
111
  async deleteBond(id) {
85
- await this.request("DELETE", `/bonds/${id}`);
112
+ await this.request("DELETE", `/api/v1/bonds/${id}`);
86
113
  }
87
114
  // ── Search ─────────────────────────────────────────
88
115
  async searchSemantic(query, options) {
89
- return this.request("POST", "/search/semantic", {
90
- query,
91
- project_id: options?.projectId,
92
- limit: options?.limit
116
+ return this.request("GET", "/api/v1/search", void 0, {
117
+ q: query,
118
+ semantic: true,
119
+ limit: options?.limit || 20,
120
+ project_id: options?.projectId
93
121
  });
94
122
  }
95
123
  async searchHybrid(query, options) {
96
- return this.request("POST", "/search/hybrid", {
97
- query,
98
- project_id: options?.projectId,
99
- limit: options?.limit
124
+ return this.request("GET", "/api/v1/search", void 0, {
125
+ q: query,
126
+ semantic: true,
127
+ limit: options?.limit || 20,
128
+ project_id: options?.projectId
129
+ });
130
+ }
131
+ async searchKeyword(query, options) {
132
+ return this.request("GET", "/api/v1/search", void 0, {
133
+ q: query,
134
+ semantic: false,
135
+ limit: options?.limit || 20,
136
+ project_id: options?.projectId
100
137
  });
101
138
  }
102
139
  // ── Assistants ─────────────────────────────────────
103
140
  async listAssistants() {
104
- return this.request("GET", "/assistants");
141
+ const res = await this.request("GET", "/api/v1/assistants");
142
+ return res.assistants;
105
143
  }
106
144
  async getAssistant(id) {
107
- return this.request("GET", `/assistants/${id}`);
145
+ const res = await this.request("GET", `/api/v1/assistants/${id}`);
146
+ return res.assistant;
108
147
  }
109
148
  async createAssistant(data) {
110
- return this.request("POST", "/assistants", data);
149
+ const res = await this.request("POST", "/api/v1/assistants/register", data);
150
+ return res.assistant;
151
+ }
152
+ async updateAssistant(id, data) {
153
+ const res = await this.request("PATCH", `/api/v1/assistants/${id}`, data);
154
+ return res.assistant;
155
+ }
156
+ async deleteAssistant(id) {
157
+ await this.request("DELETE", `/api/v1/assistants/${id}`);
158
+ }
159
+ // ── Checkout / Queue ───────────────────────────────
160
+ async checkoutAtom(atomId, mode = "exclusive", reason) {
161
+ return this.request("POST", `/api/v1/atoms/${atomId}/checkout`, { mode, reason });
162
+ }
163
+ async releaseCheckout(atomId) {
164
+ const res = await this.request("DELETE", `/api/v1/atoms/${atomId}/checkout`);
165
+ return res.success;
166
+ }
167
+ async getQueueStatus(atomId) {
168
+ return this.request("GET", `/api/v1/atoms/${atomId}/queue`);
111
169
  }
112
170
  };
113
171
  export {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sdk/client.ts"],"sourcesContent":["import type { Atom, Block, Project, Assistant, Bond, SearchResult, HealthStatus } from \"./types.js\";\n\nexport interface ClientOptions {\n baseUrl: string;\n apiKey?: string;\n timeout?: number;\n}\n\nexport class MnemosyneClient {\n private baseUrl: string;\n private apiKey?: string;\n private timeout: number;\n\n constructor(options: ClientOptions) {\n this.baseUrl = options.baseUrl.replace(/\\/$/, \"\");\n this.apiKey = options.apiKey;\n this.timeout = options.timeout || 30000;\n }\n\n private async request<T>(\n method: string,\n path: string,\n body?: unknown\n ): Promise<T> {\n const url = `${this.baseUrl}${path}`;\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), this.timeout);\n\n try {\n const headers: Record<string, string> = {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n };\n if (this.apiKey) headers[\"X-API-Key\"] = this.apiKey;\n\n const res = await fetch(url, {\n method,\n headers,\n body: body ? JSON.stringify(body) : undefined,\n signal: controller.signal,\n });\n\n if (!res.ok) {\n const text = await res.text().catch(() => \"\");\n throw new Error(`HTTP ${res.status}: ${text || res.statusText}`);\n }\n\n return (await res.json()) as T;\n } finally {\n clearTimeout(timer);\n }\n }\n\n // ── Health ─────────────────────────────────────────\n async health(): Promise<HealthStatus> {\n return this.request<HealthStatus>(\"GET\", \"/health\");\n }\n\n // ── Projects ───────────────────────────────────────\n async listProjects(): Promise<Project[]> {\n return this.request<Project[]>(\"GET\", \"/projects\");\n }\n\n async getProject(id: string): Promise<Project> {\n return this.request<Project>(\"GET\", `/projects/${id}`);\n }\n\n async createProject(data: Omit<Project, \"id\" | \"created_at\">): Promise<Project> {\n return this.request<Project>(\"POST\", \"/projects\", data);\n }\n\n async deleteProject(id: string): Promise<void> {\n await this.request(\"DELETE\", `/projects/${id}`);\n }\n\n // ── Atoms ──────────────────────────────────────────\n async listAtoms(projectId?: string): Promise<Atom[]> {\n const qs = projectId ? `?project_id=${projectId}` : \"\";\n return this.request<Atom[]>(\"GET\", `/atoms${qs}`);\n }\n\n async getAtom(id: string): Promise<Atom> {\n return this.request<Atom>(\"GET\", `/atoms/${id}`);\n }\n\n async createAtom(data: Omit<Atom, \"id\" | \"created_at\" | \"updated_at\">): Promise<Atom> {\n return this.request<Atom>(\"POST\", \"/atoms\", data);\n }\n\n async updateAtom(id: string, data: Partial<Omit<Atom, \"id\" | \"created_at\">>): Promise<Atom> {\n return this.request<Atom>(\"PUT\", `/atoms/${id}`, data);\n }\n\n async deleteAtom(id: string): Promise<void> {\n await this.request(\"DELETE\", `/atoms/${id}`);\n }\n\n // ── Blocks ─────────────────────────────────────────\n async getBlocks(atomId: string): Promise<Block[]> {\n return this.request<Block[]>(\"GET\", `/atoms/${atomId}/blocks`);\n }\n\n async createBlock(atomId: string, data: Omit<Block, \"id\" | \"atom_id\" | \"created_at\">): Promise<Block> {\n return this.request<Block>(\"POST\", `/atoms/${atomId}/blocks`, data);\n }\n\n // ── Bonds ──────────────────────────────────────────\n async listBonds(): Promise<Bond[]> {\n return this.request<Bond[]>(\"GET\", \"/bonds\");\n }\n\n async createBond(data: Omit<Bond, \"id\" | \"created_at\">): Promise<Bond> {\n return this.request<Bond>(\"POST\", \"/bonds\", data);\n }\n\n async deleteBond(id: string): Promise<void> {\n await this.request(\"DELETE\", `/bonds/${id}`);\n }\n\n // ── Search ─────────────────────────────────────────\n async searchSemantic(query: string, options?: { projectId?: string; limit?: number }): Promise<SearchResult> {\n return this.request<SearchResult>(\"POST\", \"/search/semantic\", {\n query,\n project_id: options?.projectId,\n limit: options?.limit,\n });\n }\n\n async searchHybrid(query: string, options?: { projectId?: string; limit?: number }): Promise<SearchResult> {\n return this.request<SearchResult>(\"POST\", \"/search/hybrid\", {\n query,\n project_id: options?.projectId,\n limit: options?.limit,\n });\n }\n\n // ── Assistants ─────────────────────────────────────\n async listAssistants(): Promise<Assistant[]> {\n return this.request<Assistant[]>(\"GET\", \"/assistants\");\n }\n\n async getAssistant(id: string): Promise<Assistant> {\n return this.request<Assistant>(\"GET\", `/assistants/${id}`);\n }\n\n async createAssistant(data: Omit<Assistant, \"id\" | \"created_at\">): Promise<Assistant> {\n return this.request<Assistant>(\"POST\", \"/assistants\", data);\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../src/sdk/client.ts"],"sourcesContent":["import type {\n Atom,\n Block,\n Project,\n Assistant,\n Bond,\n SearchResult,\n HealthStatus,\n CheckoutResult,\n QueueStatus,\n} from \"./types.js\";\n\nexport interface ClientOptions {\n baseUrl: string;\n apiKey?: string;\n timeout?: number;\n}\n\nexport class MnemosyneClient {\n private baseUrl: string;\n private apiKey?: string;\n private timeout: number;\n\n constructor(options: ClientOptions) {\n this.baseUrl = options.baseUrl.replace(/\\/$/, \"\");\n this.apiKey = options.apiKey;\n this.timeout = options.timeout || 30000;\n }\n\n private async request<T>(\n method: string,\n path: string,\n body?: unknown,\n query?: Record<string, string | number | boolean | undefined>\n ): Promise<T> {\n const qs = query\n ? \"?\" +\n Object.entries(query)\n .filter(([, v]) => v !== undefined)\n .map(([k, v]) => `${encodeURIComponent(k)}=${encodeURIComponent(String(v))}`)\n .join(\"&\")\n : \"\";\n const url = `${this.baseUrl}${path}${qs}`;\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), this.timeout);\n\n try {\n const headers: Record<string, string> = {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n };\n if (this.apiKey) headers[\"Authorization\"] = `Bearer ${this.apiKey}`;\n\n const res = await fetch(url, {\n method,\n headers,\n body: body ? JSON.stringify(body) : undefined,\n signal: controller.signal,\n });\n\n if (!res.ok) {\n let detail = \"\";\n try {\n const errJson = await res.json();\n detail = errJson.error || JSON.stringify(errJson);\n } catch {\n detail = await res.text().catch(() => res.statusText);\n }\n throw new Error(`HTTP ${res.status} on ${method} ${path}: ${detail || res.statusText}`);\n }\n\n return (await res.json()) as T;\n } finally {\n clearTimeout(timer);\n }\n }\n\n // ── Health ─────────────────────────────────────────\n async health(): Promise<HealthStatus> {\n return this.request<HealthStatus>(\"GET\", \"/api/v1/health\");\n }\n\n // ── Projects ───────────────────────────────────────\n async listProjects(): Promise<Project[]> {\n const res = await this.request<{ projects: Project[] }>(\"GET\", \"/api/v1/projects\");\n return res.projects;\n }\n\n async getProject(id: string): Promise<Project> {\n const res = await this.request<{ project: Project }>(\"GET\", `/api/v1/projects/${id}`);\n return res.project;\n }\n\n async createProject(data: { name: string; description?: string }): Promise<Project> {\n const res = await this.request<{ project: Project }>(\"POST\", \"/api/v1/projects\", data);\n return res.project;\n }\n\n async deleteProject(id: string): Promise<void> {\n await this.request<{ success: boolean }>(\"DELETE\", `/api/v1/projects/${id}`);\n }\n\n // ── Atoms ──────────────────────────────────────────\n async listAtoms(projectId?: string): Promise<Atom[]> {\n const res = await this.request<{ atoms: Atom[] }>(\"GET\", \"/api/v1/atoms\", undefined, { project_id: projectId });\n return res.atoms;\n }\n\n async getAtom(id: string): Promise<Atom> {\n const res = await this.request<{ atom: Atom }>(\"GET\", `/api/v1/atoms/${id}`);\n return res.atom;\n }\n\n async createAtom(data: {\n project_id: string;\n title: string;\n type?: string;\n parent_id?: string | null;\n tags?: string[];\n template?: string;\n status?: string;\n auto_path?: string;\n path_overridden?: boolean;\n }): Promise<Atom> {\n const res = await this.request<{ atom: Atom }>(\"POST\", \"/api/v1/atoms\", data);\n return res.atom;\n }\n\n async updateAtom(\n id: string,\n data: {\n title?: string;\n summary?: string;\n tags?: string[];\n status?: string;\n auto_path?: string;\n path_overridden?: boolean;\n parent_id?: string | null;\n }\n ): Promise<Atom> {\n const res = await this.request<{ atom: Atom }>(\"PATCH\", `/api/v1/atoms/${id}`, data);\n return res.atom;\n }\n\n async deleteAtom(id: string): Promise<void> {\n await this.request<{ success: boolean }>(\"DELETE\", `/api/v1/atoms/${id}`);\n }\n\n // ── Blocks ─────────────────────────────────────────\n async getBlocks(atomId: string): Promise<Block[]> {\n const res = await this.request<{ blocks: Block[] }>(\"GET\", `/api/v1/atoms/${atomId}`, undefined, { fields: \"blocks\" });\n return res.blocks || [];\n }\n\n async createBlock(\n atomId: string,\n data: { type: string; content: string; tags?: string[] }\n ): Promise<Block> {\n const res = await this.request<{ block: Block }>(\"POST\", `/api/v1/atoms/${atomId}/blocks`, data);\n return res.block;\n }\n\n async updateBlock(id: string, data: { content?: string; type?: string; metadata?: Record<string, any> }): Promise<Block> {\n const res = await this.request<{ block: Block }>(\"PATCH\", `/api/v1/blocks/${id}`, data);\n return res.block;\n }\n\n async deleteBlock(id: string): Promise<void> {\n await this.request<{ success: boolean }>(\"DELETE\", `/api/v1/blocks/${id}`);\n }\n\n // ── Bonds ──────────────────────────────────────────\n async listBonds(atomId?: string): Promise<Bond[]> {\n if (atomId) {\n const res = await this.request<{ outgoing: Bond[]; incoming: Bond[] }>(\"GET\", `/api/v1/atoms/${atomId}/bonds`);\n return [...res.outgoing, ...res.incoming];\n }\n return this.request<Bond[]>(\"GET\", \"/api/v1/bonds\");\n }\n\n async createBond(atomId: string, data: { target_id: string; label?: string; color?: string }): Promise<Bond> {\n const res = await this.request<{ bond: Bond }>(\"POST\", `/api/v1/atoms/${atomId}/bonds`, data);\n return res.bond;\n }\n\n async deleteBond(id: string): Promise<void> {\n await this.request<{ success: boolean }>(\"DELETE\", `/api/v1/bonds/${id}`);\n }\n\n // ── Search ─────────────────────────────────────────\n async searchSemantic(query: string, options?: { projectId?: string; limit?: number }): Promise<SearchResult> {\n return this.request<SearchResult>(\"GET\", \"/api/v1/search\", undefined, {\n q: query,\n semantic: true,\n limit: options?.limit || 20,\n project_id: options?.projectId,\n });\n }\n\n async searchHybrid(query: string, options?: { projectId?: string; limit?: number }): Promise<SearchResult> {\n return this.request<SearchResult>(\"GET\", \"/api/v1/search\", undefined, {\n q: query,\n semantic: true,\n limit: options?.limit || 20,\n project_id: options?.projectId,\n });\n }\n\n async searchKeyword(query: string, options?: { projectId?: string; limit?: number }): Promise<SearchResult> {\n return this.request<SearchResult>(\"GET\", \"/api/v1/search\", undefined, {\n q: query,\n semantic: false,\n limit: options?.limit || 20,\n project_id: options?.projectId,\n });\n }\n\n // ── Assistants ─────────────────────────────────────\n async listAssistants(): Promise<Assistant[]> {\n const res = await this.request<{ assistants: Assistant[] }>(\"GET\", \"/api/v1/assistants\");\n return res.assistants;\n }\n\n async getAssistant(id: string): Promise<Assistant> {\n const res = await this.request<{ assistant: Assistant }>(\"GET\", `/api/v1/assistants/${id}`);\n return res.assistant;\n }\n\n async createAssistant(data: {\n id?: string;\n name: string;\n role: string;\n capabilities?: string[];\n description?: string;\n provider?: string;\n instructions?: string;\n config?: Record<string, any>;\n }): Promise<Assistant> {\n const res = await this.request<{ assistant: Assistant }>(\"POST\", \"/api/v1/assistants/register\", data);\n return res.assistant;\n }\n\n async updateAssistant(\n id: string,\n data: {\n name?: string;\n role?: string;\n description?: string;\n provider?: string;\n instructions?: string;\n config?: Record<string, any>;\n capabilities?: string[];\n status?: string;\n }\n ): Promise<Assistant> {\n const res = await this.request<{ assistant: Assistant }>(\"PATCH\", `/api/v1/assistants/${id}`, data);\n return res.assistant;\n }\n\n async deleteAssistant(id: string): Promise<void> {\n await this.request<{ success: boolean }>(\"DELETE\", `/api/v1/assistants/${id}`);\n }\n\n // ── Checkout / Queue ───────────────────────────────\n async checkoutAtom(\n atomId: string,\n mode: \"exclusive\" | \"shared\" = \"exclusive\",\n reason?: string\n ): Promise<CheckoutResult> {\n return this.request<CheckoutResult>(\"POST\", `/api/v1/atoms/${atomId}/checkout`, { mode, reason });\n }\n\n async releaseCheckout(atomId: string): Promise<boolean> {\n const res = await this.request<{ success: boolean }>(\"DELETE\", `/api/v1/atoms/${atomId}/checkout`);\n return res.success;\n }\n\n async getQueueStatus(atomId: string): Promise<QueueStatus> {\n return this.request<QueueStatus>(\"GET\", `/api/v1/atoms/${atomId}/queue`);\n }\n}\n"],"mappings":"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","names":[]}
@@ -1,5 +1,5 @@
1
1
  import * as http from 'http';
2
- import { S as Store } from '../Store-BtdYuiUx.mjs';
2
+ import { S as Store } from '../Store-BJ8b6xbs.mjs';
3
3
  import 'better-sqlite3';
4
4
 
5
5
  declare class ApiRouter {
@@ -1,5 +1,5 @@
1
1
  import * as http from 'http';
2
- import { S as Store } from '../Store-BtdYuiUx.js';
2
+ import { S as Store } from '../Store-BJ8b6xbs.js';
3
3
  import 'better-sqlite3';
4
4
 
5
5
  declare class ApiRouter {