mnemosyne-core 2.0.3 → 2.1.0

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 +202 -50
  25. package/dist/sdk/index.d.ts +202 -50
  26. package/dist/sdk/index.js +76 -34
  27. package/dist/sdk/index.js.map +1 -1
  28. package/dist/sdk/index.mjs +76 -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
@@ -1,63 +1,104 @@
1
1
  /**
2
- * SDK shared types — mirror of core types with runtime-safe defaults.
2
+ * SDK shared types — mirror of server responses with runtime-safe defaults.
3
3
  */
4
- interface Atom {
4
+ interface Project {
5
5
  id: string;
6
6
  name: string;
7
- assistant_id: string;
8
- content_type: "text" | "image" | "audio" | "file";
9
- content: string;
10
- embedding_type?: string;
7
+ description: string | null;
8
+ icon: string;
9
+ color: string;
10
+ created_at: number;
11
+ updated_at: number;
12
+ owner: string;
13
+ metadata: Record<string, any>;
14
+ }
15
+ interface Atom {
16
+ id: string;
11
17
  project_id: string;
12
- created_at: string;
13
- updated_at: string;
18
+ parent_id: string | null;
19
+ title: string;
20
+ summary: string | null;
21
+ type: string;
22
+ icon: string;
23
+ color: string | null;
24
+ status: string;
25
+ metadata: Record<string, any>;
26
+ auto_path?: string;
27
+ path_overridden?: boolean;
28
+ status_updated_at?: number;
29
+ block_count?: number;
30
+ bond_count?: number;
31
+ template_id?: string | null;
32
+ embedding_status?: string | null;
33
+ state: {
34
+ lock: {
35
+ assistantId: string;
36
+ reason: string;
37
+ } | null;
38
+ queue: any[];
39
+ blockCount: number;
40
+ lastActivity: number;
41
+ };
14
42
  }
15
43
  interface Block {
16
44
  id: string;
17
45
  atom_id: string;
18
- block_type: "content" | "file" | "export" | "import";
19
- content: string;
20
- file_path?: string;
21
- file_original_name?: string;
22
- file_type?: string;
23
- source_type?: string;
24
- created_at: string;
46
+ type: string;
47
+ content: string | null;
48
+ order_index: number;
49
+ created_at: number;
50
+ updated_at: number;
51
+ metadata: Record<string, any>;
25
52
  }
26
- interface Project {
53
+ interface Bond {
27
54
  id: string;
28
- name: string;
29
- description?: string;
30
- created_at: string;
55
+ source_id: string;
56
+ target_id: string;
57
+ label: string;
58
+ color: string | null;
59
+ created_at: number;
31
60
  }
32
61
  interface Assistant {
33
62
  id: string;
34
63
  name: string;
35
- role?: string;
36
- model?: string;
37
- system_prompt?: string;
38
- created_at: string;
39
- }
40
- interface Bond {
41
- id: string;
42
- source_id: string;
43
- target_id: string;
44
- bond_type: "related" | "child" | "parent" | "reference";
45
- strength: number;
46
- created_at: string;
64
+ role: string;
65
+ permissions: Record<string, any>;
66
+ status: string;
67
+ provider: string | null;
68
+ connected_at: number;
69
+ last_seen: number;
70
+ metadata: Record<string, any>;
47
71
  }
48
72
  interface SearchResult {
49
- atoms: Array<Atom & {
73
+ query: string;
74
+ semantic: boolean;
75
+ count: number;
76
+ results: Array<Atom & {
50
77
  similarity?: number;
51
78
  score?: number;
52
79
  }>;
53
- time: number;
54
- total: number;
55
80
  }
56
81
  interface HealthStatus {
57
82
  status: "ok" | "degraded" | "error";
58
83
  version: string;
59
84
  database: string;
60
85
  uptime: number;
86
+ counts: Record<string, number>;
87
+ }
88
+ interface CheckoutResult {
89
+ success: boolean;
90
+ queuePosition?: number;
91
+ }
92
+ interface QueueStatus {
93
+ atomId: string;
94
+ queue: Array<{
95
+ id: string;
96
+ assistant_id: string;
97
+ requested_at: number;
98
+ priority: number;
99
+ status: string;
100
+ reason: string | null;
101
+ }>;
61
102
  }
62
103
 
63
104
  interface ClientOptions {
@@ -72,20 +113,90 @@ declare class MnemosyneClient {
72
113
  constructor(options: ClientOptions);
73
114
  private request;
74
115
  health(): Promise<HealthStatus>;
75
- listProjects(): Promise<Project[]>;
76
- getProject(id: string): Promise<Project>;
77
- createProject(data: Omit<Project, "id" | "created_at">): Promise<Project>;
78
- deleteProject(id: string): Promise<void>;
79
- listAtoms(projectId?: string): Promise<Atom[]>;
80
- getAtom(id: string): Promise<Atom>;
81
- createAtom(data: Omit<Atom, "id" | "created_at" | "updated_at">): Promise<Atom>;
82
- updateAtom(id: string, data: Partial<Omit<Atom, "id" | "created_at">>): Promise<Atom>;
83
- deleteAtom(id: string): Promise<void>;
116
+ listProjects(): Promise<{
117
+ projects: Project[];
118
+ }>;
119
+ getProject(id: string): Promise<{
120
+ project: Project;
121
+ }>;
122
+ createProject(data: {
123
+ name: string;
124
+ description?: string;
125
+ }): Promise<{
126
+ success: boolean;
127
+ project: Project;
128
+ }>;
129
+ deleteProject(id: string): Promise<{
130
+ success: boolean;
131
+ }>;
132
+ listAtoms(projectId?: string): Promise<{
133
+ atoms: Atom[];
134
+ }>;
135
+ getAtom(id: string): Promise<{
136
+ atom: Atom;
137
+ children: any[];
138
+ blocks: Block[];
139
+ bonds: Bond[];
140
+ }>;
141
+ createAtom(data: {
142
+ project_id: string;
143
+ title: string;
144
+ type?: string;
145
+ parent_id?: string | null;
146
+ tags?: string[];
147
+ template?: string;
148
+ status?: string;
149
+ auto_path?: string;
150
+ path_overridden?: boolean;
151
+ }): Promise<{
152
+ atom: Atom;
153
+ }>;
154
+ updateAtom(id: string, data: {
155
+ title?: string;
156
+ summary?: string;
157
+ tags?: string[];
158
+ status?: string;
159
+ auto_path?: string;
160
+ path_overridden?: boolean;
161
+ parent_id?: string | null;
162
+ }): Promise<{
163
+ atom: Atom;
164
+ }>;
165
+ deleteAtom(id: string): Promise<{
166
+ success: boolean;
167
+ }>;
84
168
  getBlocks(atomId: string): Promise<Block[]>;
85
- createBlock(atomId: string, data: Omit<Block, "id" | "atom_id" | "created_at">): Promise<Block>;
86
- listBonds(): Promise<Bond[]>;
87
- createBond(data: Omit<Bond, "id" | "created_at">): Promise<Bond>;
88
- deleteBond(id: string): Promise<void>;
169
+ createBlock(atomId: string, data: {
170
+ type: string;
171
+ content: string;
172
+ tags?: string[];
173
+ }): Promise<{
174
+ block: Block;
175
+ }>;
176
+ updateBlock(id: string, data: {
177
+ content?: string;
178
+ type?: string;
179
+ metadata?: Record<string, any>;
180
+ }): Promise<{
181
+ block: Block;
182
+ }>;
183
+ deleteBlock(id: string): Promise<{
184
+ success: boolean;
185
+ }>;
186
+ listBonds(atomId?: string): Promise<Bond[] | {
187
+ outgoing: Bond[];
188
+ incoming: Bond[];
189
+ }>;
190
+ createBond(atomId: string, data: {
191
+ target_id: string;
192
+ label?: string;
193
+ color?: string;
194
+ }): Promise<{
195
+ bond: Bond;
196
+ }>;
197
+ deleteBond(id: string): Promise<{
198
+ success: boolean;
199
+ }>;
89
200
  searchSemantic(query: string, options?: {
90
201
  projectId?: string;
91
202
  limit?: number;
@@ -94,9 +205,50 @@ declare class MnemosyneClient {
94
205
  projectId?: string;
95
206
  limit?: number;
96
207
  }): Promise<SearchResult>;
97
- listAssistants(): Promise<Assistant[]>;
98
- getAssistant(id: string): Promise<Assistant>;
99
- createAssistant(data: Omit<Assistant, "id" | "created_at">): Promise<Assistant>;
208
+ searchKeyword(query: string, options?: {
209
+ projectId?: string;
210
+ limit?: number;
211
+ }): Promise<SearchResult>;
212
+ listAssistants(): Promise<{
213
+ assistants: Assistant[];
214
+ }>;
215
+ getAssistant(id: string): Promise<{
216
+ assistant: Assistant;
217
+ }>;
218
+ createAssistant(data: {
219
+ id?: string;
220
+ name: string;
221
+ role: string;
222
+ capabilities?: string[];
223
+ description?: string;
224
+ provider?: string;
225
+ instructions?: string;
226
+ config?: Record<string, any>;
227
+ }): Promise<{
228
+ success: boolean;
229
+ token: string;
230
+ assistant: Assistant;
231
+ }>;
232
+ updateAssistant(id: string, data: {
233
+ name?: string;
234
+ role?: string;
235
+ description?: string;
236
+ provider?: string;
237
+ instructions?: string;
238
+ config?: Record<string, any>;
239
+ capabilities?: string[];
240
+ status?: string;
241
+ }): Promise<{
242
+ assistant: Assistant;
243
+ }>;
244
+ deleteAssistant(id: string): Promise<{
245
+ success: boolean;
246
+ }>;
247
+ checkoutAtom(atomId: string, mode?: "exclusive" | "shared", reason?: string): Promise<CheckoutResult>;
248
+ releaseCheckout(atomId: string): Promise<{
249
+ success: boolean;
250
+ }>;
251
+ getQueueStatus(atomId: string): Promise<QueueStatus>;
100
252
  }
101
253
 
102
254
  export { type Assistant, type Atom, type Block, type Bond, type HealthStatus, MnemosyneClient, type Project, type SearchResult };
package/dist/sdk/index.js CHANGED
@@ -34,8 +34,9 @@ var MnemosyneClient = class {
34
34
  this.apiKey = options.apiKey;
35
35
  this.timeout = options.timeout || 3e4;
36
36
  }
37
- async request(method, path, body) {
38
- const url = `${this.baseUrl}${path}`;
37
+ async request(method, path, body, query) {
38
+ const qs = query ? "?" + Object.entries(query).filter(([, v]) => v !== void 0).map(([k, v]) => `${encodeURIComponent(k)}=${encodeURIComponent(String(v))}`).join("&") : "";
39
+ const url = `${this.baseUrl}${path}${qs}`;
39
40
  const controller = new AbortController();
40
41
  const timer = setTimeout(() => controller.abort(), this.timeout);
41
42
  try {
@@ -43,7 +44,7 @@ var MnemosyneClient = class {
43
44
  Accept: "application/json",
44
45
  "Content-Type": "application/json"
45
46
  };
46
- if (this.apiKey) headers["X-API-Key"] = this.apiKey;
47
+ if (this.apiKey) headers["Authorization"] = `Bearer ${this.apiKey}`;
47
48
  const res = await fetch(url, {
48
49
  method,
49
50
  headers,
@@ -51,8 +52,14 @@ var MnemosyneClient = class {
51
52
  signal: controller.signal
52
53
  });
53
54
  if (!res.ok) {
54
- const text = await res.text().catch(() => "");
55
- throw new Error(`HTTP ${res.status}: ${text || res.statusText}`);
55
+ let detail = "";
56
+ try {
57
+ const errJson = await res.json();
58
+ detail = errJson.error || JSON.stringify(errJson);
59
+ } catch {
60
+ detail = await res.text().catch(() => res.statusText);
61
+ }
62
+ throw new Error(`HTTP ${res.status} on ${method} ${path}: ${detail || res.statusText}`);
56
63
  }
57
64
  return await res.json();
58
65
  } finally {
@@ -61,79 +68,114 @@ var MnemosyneClient = class {
61
68
  }
62
69
  // ── Health ─────────────────────────────────────────
63
70
  async health() {
64
- return this.request("GET", "/health");
71
+ return this.request("GET", "/api/v1/health");
65
72
  }
66
73
  // ── Projects ───────────────────────────────────────
67
74
  async listProjects() {
68
- return this.request("GET", "/projects");
75
+ return this.request("GET", "/api/v1/projects");
69
76
  }
70
77
  async getProject(id) {
71
- return this.request("GET", `/projects/${id}`);
78
+ return this.request("GET", `/api/v1/projects/${id}`);
72
79
  }
73
80
  async createProject(data) {
74
- return this.request("POST", "/projects", data);
81
+ return this.request("POST", "/api/v1/projects", data);
75
82
  }
76
83
  async deleteProject(id) {
77
- await this.request("DELETE", `/projects/${id}`);
84
+ return this.request("DELETE", `/api/v1/projects/${id}`);
78
85
  }
79
86
  // ── Atoms ──────────────────────────────────────────
80
87
  async listAtoms(projectId) {
81
- const qs = projectId ? `?project_id=${projectId}` : "";
82
- return this.request("GET", `/atoms${qs}`);
88
+ return this.request("GET", "/api/v1/atoms", void 0, { project_id: projectId });
83
89
  }
84
90
  async getAtom(id) {
85
- return this.request("GET", `/atoms/${id}`);
91
+ return this.request("GET", `/api/v1/atoms/${id}`);
86
92
  }
87
93
  async createAtom(data) {
88
- return this.request("POST", "/atoms", data);
94
+ return this.request("POST", "/api/v1/atoms", data);
89
95
  }
90
96
  async updateAtom(id, data) {
91
- return this.request("PUT", `/atoms/${id}`, data);
97
+ return this.request("PATCH", `/api/v1/atoms/${id}`, data);
92
98
  }
93
99
  async deleteAtom(id) {
94
- await this.request("DELETE", `/atoms/${id}`);
100
+ return this.request("DELETE", `/api/v1/atoms/${id}`);
95
101
  }
96
102
  // ── Blocks ─────────────────────────────────────────
97
103
  async getBlocks(atomId) {
98
- return this.request("GET", `/atoms/${atomId}/blocks`);
104
+ const res = await this.request("GET", `/api/v1/atoms/${atomId}`, void 0, { fields: "blocks" });
105
+ return res.blocks || [];
99
106
  }
100
107
  async createBlock(atomId, data) {
101
- return this.request("POST", `/atoms/${atomId}/blocks`, data);
108
+ return this.request("POST", `/api/v1/atoms/${atomId}/blocks`, data);
109
+ }
110
+ async updateBlock(id, data) {
111
+ return this.request("PATCH", `/api/v1/blocks/${id}`, data);
112
+ }
113
+ async deleteBlock(id) {
114
+ return this.request("DELETE", `/api/v1/blocks/${id}`);
102
115
  }
103
116
  // ── Bonds ──────────────────────────────────────────
104
- async listBonds() {
105
- return this.request("GET", "/bonds");
117
+ async listBonds(atomId) {
118
+ if (atomId) {
119
+ return this.request("GET", `/api/v1/atoms/${atomId}/bonds`);
120
+ }
121
+ return this.request("GET", "/api/v1/bonds");
106
122
  }
107
- async createBond(data) {
108
- return this.request("POST", "/bonds", data);
123
+ async createBond(atomId, data) {
124
+ return this.request("POST", `/api/v1/atoms/${atomId}/bonds`, data);
109
125
  }
110
126
  async deleteBond(id) {
111
- await this.request("DELETE", `/bonds/${id}`);
127
+ return this.request("DELETE", `/api/v1/bonds/${id}`);
112
128
  }
113
129
  // ── Search ─────────────────────────────────────────
114
130
  async searchSemantic(query, options) {
115
- return this.request("POST", "/search/semantic", {
116
- query,
117
- project_id: options?.projectId,
118
- limit: options?.limit
131
+ return this.request("GET", "/api/v1/search", void 0, {
132
+ q: query,
133
+ semantic: true,
134
+ limit: options?.limit || 20,
135
+ project_id: options?.projectId
119
136
  });
120
137
  }
121
138
  async searchHybrid(query, options) {
122
- return this.request("POST", "/search/hybrid", {
123
- query,
124
- project_id: options?.projectId,
125
- limit: options?.limit
139
+ return this.request("GET", "/api/v1/search", void 0, {
140
+ q: query,
141
+ semantic: true,
142
+ limit: options?.limit || 20,
143
+ project_id: options?.projectId
144
+ });
145
+ }
146
+ async searchKeyword(query, options) {
147
+ return this.request("GET", "/api/v1/search", void 0, {
148
+ q: query,
149
+ semantic: false,
150
+ limit: options?.limit || 20,
151
+ project_id: options?.projectId
126
152
  });
127
153
  }
128
154
  // ── Assistants ─────────────────────────────────────
129
155
  async listAssistants() {
130
- return this.request("GET", "/assistants");
156
+ return this.request("GET", "/api/v1/assistants");
131
157
  }
132
158
  async getAssistant(id) {
133
- return this.request("GET", `/assistants/${id}`);
159
+ return this.request("GET", `/api/v1/assistants/${id}`);
134
160
  }
135
161
  async createAssistant(data) {
136
- return this.request("POST", "/assistants", data);
162
+ return this.request("POST", "/api/v1/assistants/register", data);
163
+ }
164
+ async updateAssistant(id, data) {
165
+ return this.request("PATCH", `/api/v1/assistants/${id}`, data);
166
+ }
167
+ async deleteAssistant(id) {
168
+ return this.request("DELETE", `/api/v1/assistants/${id}`);
169
+ }
170
+ // ── Checkout / Queue ───────────────────────────────
171
+ async checkoutAtom(atomId, mode = "exclusive", reason) {
172
+ return this.request("POST", `/api/v1/atoms/${atomId}/checkout`, { mode, reason });
173
+ }
174
+ async releaseCheckout(atomId) {
175
+ return this.request("DELETE", `/api/v1/atoms/${atomId}/checkout`);
176
+ }
177
+ async getQueueStatus(atomId) {
178
+ return this.request("GET", `/api/v1/atoms/${atomId}/queue`);
137
179
  }
138
180
  };
139
181
  // Annotate the CommonJS export names for ESM import in node:
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sdk/index.ts","../../src/sdk/client.ts"],"sourcesContent":["export { MnemosyneClient } from \"./client.js\";\nexport type {\n Atom,\n Block,\n Project,\n Assistant,\n Bond,\n SearchResult,\n HealthStatus,\n} from \"./types.js\";\n","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/index.ts","../../src/sdk/client.ts"],"sourcesContent":["export { MnemosyneClient } from \"./client.js\";\nexport type {\n Atom,\n Block,\n Project,\n Assistant,\n Bond,\n SearchResult,\n HealthStatus,\n} from \"./types.js\";\n","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<{ projects: Project[] }> {\n return this.request<{ projects: Project[] }>(\"GET\", \"/api/v1/projects\");\n }\n\n async getProject(id: string): Promise<{ project: Project }> {\n return this.request<{ project: Project }>(\"GET\", `/api/v1/projects/${id}`);\n }\n\n async createProject(data: { name: string; description?: string }): Promise<{ success: boolean; project: Project }> {\n return this.request<{ success: boolean; project: Project }>(\"POST\", \"/api/v1/projects\", data);\n }\n\n async deleteProject(id: string): Promise<{ success: boolean }> {\n return this.request<{ success: boolean }>(\"DELETE\", `/api/v1/projects/${id}`);\n }\n\n // ── Atoms ──────────────────────────────────────────\n async listAtoms(projectId?: string): Promise<{ atoms: Atom[] }> {\n return this.request<{ atoms: Atom[] }>(\"GET\", \"/api/v1/atoms\", undefined, { project_id: projectId });\n }\n\n async getAtom(id: string): Promise<{ atom: Atom; children: any[]; blocks: Block[]; bonds: Bond[] }> {\n return this.request<any>(\"GET\", `/api/v1/atoms/${id}`);\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: Atom }> {\n return this.request<{ atom: Atom }>(\"POST\", \"/api/v1/atoms\", data);\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: Atom }> {\n return this.request<{ atom: Atom }>(\"PATCH\", `/api/v1/atoms/${id}`, data);\n }\n\n async deleteAtom(id: string): Promise<{ success: boolean }> {\n return 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: Block }> {\n return this.request<{ block: Block }>(\"POST\", `/api/v1/atoms/${atomId}/blocks`, data);\n }\n\n async updateBlock(id: string, data: { content?: string; type?: string; metadata?: Record<string, any> }): Promise<{ block: Block }> {\n return this.request<{ block: Block }>(\"PATCH\", `/api/v1/blocks/${id}`, data);\n }\n\n async deleteBlock(id: string): Promise<{ success: boolean }> {\n return this.request<{ success: boolean }>(\"DELETE\", `/api/v1/blocks/${id}`);\n }\n\n // ── Bonds ──────────────────────────────────────────\n async listBonds(atomId?: string): Promise<Bond[] | { outgoing: Bond[]; incoming: Bond[] }> {\n if (atomId) {\n return this.request<{ outgoing: Bond[]; incoming: Bond[] }>(\"GET\", `/api/v1/atoms/${atomId}/bonds`);\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: Bond }> {\n return this.request<{ bond: Bond }>(\"POST\", `/api/v1/atoms/${atomId}/bonds`, data);\n }\n\n async deleteBond(id: string): Promise<{ success: boolean }> {\n return 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<{ assistants: Assistant[] }> {\n return this.request<{ assistants: Assistant[] }>(\"GET\", \"/api/v1/assistants\");\n }\n\n async getAssistant(id: string): Promise<{ assistant: Assistant }> {\n return this.request<{ assistant: Assistant }>(\"GET\", `/api/v1/assistants/${id}`);\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<{ success: boolean; token: string; assistant: Assistant }> {\n return this.request<any>(\"POST\", \"/api/v1/assistants/register\", data);\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: Assistant }> {\n return this.request<{ assistant: Assistant }>(\"PATCH\", `/api/v1/assistants/${id}`, data);\n }\n\n async deleteAssistant(id: string): Promise<{ success: boolean }> {\n return 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<{ success: boolean }> {\n return this.request<{ success: boolean }>(\"DELETE\", `/api/v1/atoms/${atomId}/checkout`);\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":[]}