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
@@ -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 {
@@ -74,17 +115,52 @@ declare class MnemosyneClient {
74
115
  health(): Promise<HealthStatus>;
75
116
  listProjects(): Promise<Project[]>;
76
117
  getProject(id: string): Promise<Project>;
77
- createProject(data: Omit<Project, "id" | "created_at">): Promise<Project>;
118
+ createProject(data: {
119
+ name: string;
120
+ description?: string;
121
+ }): Promise<Project>;
78
122
  deleteProject(id: string): Promise<void>;
79
123
  listAtoms(projectId?: string): Promise<Atom[]>;
80
124
  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>;
125
+ createAtom(data: {
126
+ project_id: string;
127
+ title: string;
128
+ type?: string;
129
+ parent_id?: string | null;
130
+ tags?: string[];
131
+ template?: string;
132
+ status?: string;
133
+ auto_path?: string;
134
+ path_overridden?: boolean;
135
+ }): Promise<Atom>;
136
+ updateAtom(id: string, data: {
137
+ title?: string;
138
+ summary?: string;
139
+ tags?: string[];
140
+ status?: string;
141
+ auto_path?: string;
142
+ path_overridden?: boolean;
143
+ parent_id?: string | null;
144
+ }): Promise<Atom>;
83
145
  deleteAtom(id: string): Promise<void>;
84
146
  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>;
147
+ createBlock(atomId: string, data: {
148
+ type: string;
149
+ content: string;
150
+ tags?: string[];
151
+ }): Promise<Block>;
152
+ updateBlock(id: string, data: {
153
+ content?: string;
154
+ type?: string;
155
+ metadata?: Record<string, any>;
156
+ }): Promise<Block>;
157
+ deleteBlock(id: string): Promise<void>;
158
+ listBonds(atomId?: string): Promise<Bond[]>;
159
+ createBond(atomId: string, data: {
160
+ target_id: string;
161
+ label?: string;
162
+ color?: string;
163
+ }): Promise<Bond>;
88
164
  deleteBond(id: string): Promise<void>;
89
165
  searchSemantic(query: string, options?: {
90
166
  projectId?: string;
@@ -94,9 +170,36 @@ declare class MnemosyneClient {
94
170
  projectId?: string;
95
171
  limit?: number;
96
172
  }): Promise<SearchResult>;
173
+ searchKeyword(query: string, options?: {
174
+ projectId?: string;
175
+ limit?: number;
176
+ }): Promise<SearchResult>;
97
177
  listAssistants(): Promise<Assistant[]>;
98
178
  getAssistant(id: string): Promise<Assistant>;
99
- createAssistant(data: Omit<Assistant, "id" | "created_at">): Promise<Assistant>;
179
+ createAssistant(data: {
180
+ id?: string;
181
+ name: string;
182
+ role: string;
183
+ capabilities?: string[];
184
+ description?: string;
185
+ provider?: string;
186
+ instructions?: string;
187
+ config?: Record<string, any>;
188
+ }): Promise<Assistant>;
189
+ updateAssistant(id: string, data: {
190
+ name?: string;
191
+ role?: string;
192
+ description?: string;
193
+ provider?: string;
194
+ instructions?: string;
195
+ config?: Record<string, any>;
196
+ capabilities?: string[];
197
+ status?: string;
198
+ }): Promise<Assistant>;
199
+ deleteAssistant(id: string): Promise<void>;
200
+ checkoutAtom(atomId: string, mode?: "exclusive" | "shared", reason?: string): Promise<CheckoutResult>;
201
+ releaseCheckout(atomId: string): Promise<boolean>;
202
+ getQueueStatus(atomId: string): Promise<QueueStatus>;
100
203
  }
101
204
 
102
205
  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,130 @@ 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
+ const res = await this.request("GET", "/api/v1/projects");
76
+ return res.projects;
69
77
  }
70
78
  async getProject(id) {
71
- return this.request("GET", `/projects/${id}`);
79
+ const res = await this.request("GET", `/api/v1/projects/${id}`);
80
+ return res.project;
72
81
  }
73
82
  async createProject(data) {
74
- return this.request("POST", "/projects", data);
83
+ const res = await this.request("POST", "/api/v1/projects", data);
84
+ return res.project;
75
85
  }
76
86
  async deleteProject(id) {
77
- await this.request("DELETE", `/projects/${id}`);
87
+ await this.request("DELETE", `/api/v1/projects/${id}`);
78
88
  }
79
89
  // ── Atoms ──────────────────────────────────────────
80
90
  async listAtoms(projectId) {
81
- const qs = projectId ? `?project_id=${projectId}` : "";
82
- return this.request("GET", `/atoms${qs}`);
91
+ const res = await this.request("GET", "/api/v1/atoms", void 0, { project_id: projectId });
92
+ return res.atoms;
83
93
  }
84
94
  async getAtom(id) {
85
- return this.request("GET", `/atoms/${id}`);
95
+ const res = await this.request("GET", `/api/v1/atoms/${id}`);
96
+ return res.atom;
86
97
  }
87
98
  async createAtom(data) {
88
- return this.request("POST", "/atoms", data);
99
+ const res = await this.request("POST", "/api/v1/atoms", data);
100
+ return res.atom;
89
101
  }
90
102
  async updateAtom(id, data) {
91
- return this.request("PUT", `/atoms/${id}`, data);
103
+ const res = await this.request("PATCH", `/api/v1/atoms/${id}`, data);
104
+ return res.atom;
92
105
  }
93
106
  async deleteAtom(id) {
94
- await this.request("DELETE", `/atoms/${id}`);
107
+ await this.request("DELETE", `/api/v1/atoms/${id}`);
95
108
  }
96
109
  // ── Blocks ─────────────────────────────────────────
97
110
  async getBlocks(atomId) {
98
- return this.request("GET", `/atoms/${atomId}/blocks`);
111
+ const res = await this.request("GET", `/api/v1/atoms/${atomId}`, void 0, { fields: "blocks" });
112
+ return res.blocks || [];
99
113
  }
100
114
  async createBlock(atomId, data) {
101
- return this.request("POST", `/atoms/${atomId}/blocks`, data);
115
+ const res = await this.request("POST", `/api/v1/atoms/${atomId}/blocks`, data);
116
+ return res.block;
117
+ }
118
+ async updateBlock(id, data) {
119
+ const res = await this.request("PATCH", `/api/v1/blocks/${id}`, data);
120
+ return res.block;
121
+ }
122
+ async deleteBlock(id) {
123
+ await this.request("DELETE", `/api/v1/blocks/${id}`);
102
124
  }
103
125
  // ── Bonds ──────────────────────────────────────────
104
- async listBonds() {
105
- return this.request("GET", "/bonds");
126
+ async listBonds(atomId) {
127
+ if (atomId) {
128
+ const res = await this.request("GET", `/api/v1/atoms/${atomId}/bonds`);
129
+ return [...res.outgoing, ...res.incoming];
130
+ }
131
+ return this.request("GET", "/api/v1/bonds");
106
132
  }
107
- async createBond(data) {
108
- return this.request("POST", "/bonds", data);
133
+ async createBond(atomId, data) {
134
+ const res = await this.request("POST", `/api/v1/atoms/${atomId}/bonds`, data);
135
+ return res.bond;
109
136
  }
110
137
  async deleteBond(id) {
111
- await this.request("DELETE", `/bonds/${id}`);
138
+ await this.request("DELETE", `/api/v1/bonds/${id}`);
112
139
  }
113
140
  // ── Search ─────────────────────────────────────────
114
141
  async searchSemantic(query, options) {
115
- return this.request("POST", "/search/semantic", {
116
- query,
117
- project_id: options?.projectId,
118
- limit: options?.limit
142
+ return this.request("GET", "/api/v1/search", void 0, {
143
+ q: query,
144
+ semantic: true,
145
+ limit: options?.limit || 20,
146
+ project_id: options?.projectId
119
147
  });
120
148
  }
121
149
  async searchHybrid(query, options) {
122
- return this.request("POST", "/search/hybrid", {
123
- query,
124
- project_id: options?.projectId,
125
- limit: options?.limit
150
+ return this.request("GET", "/api/v1/search", void 0, {
151
+ q: query,
152
+ semantic: true,
153
+ limit: options?.limit || 20,
154
+ project_id: options?.projectId
155
+ });
156
+ }
157
+ async searchKeyword(query, options) {
158
+ return this.request("GET", "/api/v1/search", void 0, {
159
+ q: query,
160
+ semantic: false,
161
+ limit: options?.limit || 20,
162
+ project_id: options?.projectId
126
163
  });
127
164
  }
128
165
  // ── Assistants ─────────────────────────────────────
129
166
  async listAssistants() {
130
- return this.request("GET", "/assistants");
167
+ const res = await this.request("GET", "/api/v1/assistants");
168
+ return res.assistants;
131
169
  }
132
170
  async getAssistant(id) {
133
- return this.request("GET", `/assistants/${id}`);
171
+ const res = await this.request("GET", `/api/v1/assistants/${id}`);
172
+ return res.assistant;
134
173
  }
135
174
  async createAssistant(data) {
136
- return this.request("POST", "/assistants", data);
175
+ const res = await this.request("POST", "/api/v1/assistants/register", data);
176
+ return res.assistant;
177
+ }
178
+ async updateAssistant(id, data) {
179
+ const res = await this.request("PATCH", `/api/v1/assistants/${id}`, data);
180
+ return res.assistant;
181
+ }
182
+ async deleteAssistant(id) {
183
+ await this.request("DELETE", `/api/v1/assistants/${id}`);
184
+ }
185
+ // ── Checkout / Queue ───────────────────────────────
186
+ async checkoutAtom(atomId, mode = "exclusive", reason) {
187
+ return this.request("POST", `/api/v1/atoms/${atomId}/checkout`, { mode, reason });
188
+ }
189
+ async releaseCheckout(atomId) {
190
+ const res = await this.request("DELETE", `/api/v1/atoms/${atomId}/checkout`);
191
+ return res.success;
192
+ }
193
+ async getQueueStatus(atomId) {
194
+ return this.request("GET", `/api/v1/atoms/${atomId}/queue`);
137
195
  }
138
196
  };
139
197
  // 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":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACQO,IAAM,kBAAN,MAAsB;AAAA,EACnB;AAAA,EACA;AAAA,EACA;AAAA,EAER,YAAY,SAAwB;AAClC,SAAK,UAAU,QAAQ,QAAQ,QAAQ,OAAO,EAAE;AAChD,SAAK,SAAS,QAAQ;AACtB,SAAK,UAAU,QAAQ,WAAW;AAAA,EACpC;AAAA,EAEA,MAAc,QACZ,QACA,MACA,MACY;AACZ,UAAM,MAAM,GAAG,KAAK,OAAO,GAAG,IAAI;AAClC,UAAM,aAAa,IAAI,gBAAgB;AACvC,UAAM,QAAQ,WAAW,MAAM,WAAW,MAAM,GAAG,KAAK,OAAO;AAE/D,QAAI;AACF,YAAM,UAAkC;AAAA,QACtC,QAAQ;AAAA,QACR,gBAAgB;AAAA,MAClB;AACA,UAAI,KAAK,OAAQ,SAAQ,WAAW,IAAI,KAAK;AAE7C,YAAM,MAAM,MAAM,MAAM,KAAK;AAAA,QAC3B;AAAA,QACA;AAAA,QACA,MAAM,OAAO,KAAK,UAAU,IAAI,IAAI;AAAA,QACpC,QAAQ,WAAW;AAAA,MACrB,CAAC;AAED,UAAI,CAAC,IAAI,IAAI;AACX,cAAM,OAAO,MAAM,IAAI,KAAK,EAAE,MAAM,MAAM,EAAE;AAC5C,cAAM,IAAI,MAAM,QAAQ,IAAI,MAAM,KAAK,QAAQ,IAAI,UAAU,EAAE;AAAA,MACjE;AAEA,aAAQ,MAAM,IAAI,KAAK;AAAA,IACzB,UAAE;AACA,mBAAa,KAAK;AAAA,IACpB;AAAA,EACF;AAAA;AAAA,EAGA,MAAM,SAAgC;AACpC,WAAO,KAAK,QAAsB,OAAO,SAAS;AAAA,EACpD;AAAA;AAAA,EAGA,MAAM,eAAmC;AACvC,WAAO,KAAK,QAAmB,OAAO,WAAW;AAAA,EACnD;AAAA,EAEA,MAAM,WAAW,IAA8B;AAC7C,WAAO,KAAK,QAAiB,OAAO,aAAa,EAAE,EAAE;AAAA,EACvD;AAAA,EAEA,MAAM,cAAc,MAA4D;AAC9E,WAAO,KAAK,QAAiB,QAAQ,aAAa,IAAI;AAAA,EACxD;AAAA,EAEA,MAAM,cAAc,IAA2B;AAC7C,UAAM,KAAK,QAAQ,UAAU,aAAa,EAAE,EAAE;AAAA,EAChD;AAAA;AAAA,EAGA,MAAM,UAAU,WAAqC;AACnD,UAAM,KAAK,YAAY,eAAe,SAAS,KAAK;AACpD,WAAO,KAAK,QAAgB,OAAO,SAAS,EAAE,EAAE;AAAA,EAClD;AAAA,EAEA,MAAM,QAAQ,IAA2B;AACvC,WAAO,KAAK,QAAc,OAAO,UAAU,EAAE,EAAE;AAAA,EACjD;AAAA,EAEA,MAAM,WAAW,MAAqE;AACpF,WAAO,KAAK,QAAc,QAAQ,UAAU,IAAI;AAAA,EAClD;AAAA,EAEA,MAAM,WAAW,IAAY,MAA+D;AAC1F,WAAO,KAAK,QAAc,OAAO,UAAU,EAAE,IAAI,IAAI;AAAA,EACvD;AAAA,EAEA,MAAM,WAAW,IAA2B;AAC1C,UAAM,KAAK,QAAQ,UAAU,UAAU,EAAE,EAAE;AAAA,EAC7C;AAAA;AAAA,EAGA,MAAM,UAAU,QAAkC;AAChD,WAAO,KAAK,QAAiB,OAAO,UAAU,MAAM,SAAS;AAAA,EAC/D;AAAA,EAEA,MAAM,YAAY,QAAgB,MAAoE;AACpG,WAAO,KAAK,QAAe,QAAQ,UAAU,MAAM,WAAW,IAAI;AAAA,EACpE;AAAA;AAAA,EAGA,MAAM,YAA6B;AACjC,WAAO,KAAK,QAAgB,OAAO,QAAQ;AAAA,EAC7C;AAAA,EAEA,MAAM,WAAW,MAAsD;AACrE,WAAO,KAAK,QAAc,QAAQ,UAAU,IAAI;AAAA,EAClD;AAAA,EAEA,MAAM,WAAW,IAA2B;AAC1C,UAAM,KAAK,QAAQ,UAAU,UAAU,EAAE,EAAE;AAAA,EAC7C;AAAA;AAAA,EAGA,MAAM,eAAe,OAAe,SAAyE;AAC3G,WAAO,KAAK,QAAsB,QAAQ,oBAAoB;AAAA,MAC5D;AAAA,MACA,YAAY,SAAS;AAAA,MACrB,OAAO,SAAS;AAAA,IAClB,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,aAAa,OAAe,SAAyE;AACzG,WAAO,KAAK,QAAsB,QAAQ,kBAAkB;AAAA,MAC1D;AAAA,MACA,YAAY,SAAS;AAAA,MACrB,OAAO,SAAS;AAAA,IAClB,CAAC;AAAA,EACH;AAAA;AAAA,EAGA,MAAM,iBAAuC;AAC3C,WAAO,KAAK,QAAqB,OAAO,aAAa;AAAA,EACvD;AAAA,EAEA,MAAM,aAAa,IAAgC;AACjD,WAAO,KAAK,QAAmB,OAAO,eAAe,EAAE,EAAE;AAAA,EAC3D;AAAA,EAEA,MAAM,gBAAgB,MAAgE;AACpF,WAAO,KAAK,QAAmB,QAAQ,eAAe,IAAI;AAAA,EAC5D;AACF;","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<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":[]}