@lanonasis/mem-intel-sdk 1.0.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 (66) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/LICENSE +21 -0
  3. package/README.md +490 -0
  4. package/dist/core/client.d.ts +43 -0
  5. package/dist/core/client.d.ts.map +1 -0
  6. package/dist/core/errors.d.ts +24 -0
  7. package/dist/core/errors.d.ts.map +1 -0
  8. package/dist/core/index.cjs +310 -0
  9. package/dist/core/index.cjs.map +1 -0
  10. package/dist/core/index.d.ts +7 -0
  11. package/dist/core/index.d.ts.map +1 -0
  12. package/dist/core/index.js +300 -0
  13. package/dist/core/index.js.map +1 -0
  14. package/dist/core/types.d.ts +171 -0
  15. package/dist/core/types.d.ts.map +1 -0
  16. package/dist/index-sdk.d.ts +8 -0
  17. package/dist/index-sdk.d.ts.map +1 -0
  18. package/dist/index.cjs +310 -0
  19. package/dist/index.cjs.map +1 -0
  20. package/dist/index.js +300 -0
  21. package/dist/index.js.map +1 -0
  22. package/dist/node/client.d.ts +22 -0
  23. package/dist/node/client.d.ts.map +1 -0
  24. package/dist/node/index.cjs +331 -0
  25. package/dist/node/index.cjs.map +1 -0
  26. package/dist/node/index.d.ts +7 -0
  27. package/dist/node/index.d.ts.map +1 -0
  28. package/dist/node/index.js +321 -0
  29. package/dist/node/index.js.map +1 -0
  30. package/dist/react/context/MemoryIntelligenceProvider.d.ts +18 -0
  31. package/dist/react/context/MemoryIntelligenceProvider.d.ts.map +1 -0
  32. package/dist/react/hooks/useMemoryIntelligence.d.ts +115 -0
  33. package/dist/react/hooks/useMemoryIntelligence.d.ts.map +1 -0
  34. package/dist/react/index.cjs +399 -0
  35. package/dist/react/index.cjs.map +1 -0
  36. package/dist/react/index.d.ts +8 -0
  37. package/dist/react/index.d.ts.map +1 -0
  38. package/dist/react/index.js +377 -0
  39. package/dist/react/index.js.map +1 -0
  40. package/dist/server/index.cjs +802 -0
  41. package/dist/server/index.cjs.map +1 -0
  42. package/dist/server/index.d.ts +7 -0
  43. package/dist/server/index.d.ts.map +1 -0
  44. package/dist/server/index.js +792 -0
  45. package/dist/server/index.js.map +1 -0
  46. package/dist/server/mcp-server.d.ts +7 -0
  47. package/dist/server/mcp-server.d.ts.map +1 -0
  48. package/dist/utils/embeddings.d.ts +13 -0
  49. package/dist/utils/embeddings.d.ts.map +1 -0
  50. package/dist/utils/formatting.d.ts +13 -0
  51. package/dist/utils/formatting.d.ts.map +1 -0
  52. package/dist/utils/http-client.d.ts +31 -0
  53. package/dist/utils/http-client.d.ts.map +1 -0
  54. package/dist/utils/index.d.ts +9 -0
  55. package/dist/utils/index.d.ts.map +1 -0
  56. package/dist/utils/similarity.d.ts +8 -0
  57. package/dist/utils/similarity.d.ts.map +1 -0
  58. package/dist/vue/composables/useMemoryIntelligence.d.ts +24 -0
  59. package/dist/vue/composables/useMemoryIntelligence.d.ts.map +1 -0
  60. package/dist/vue/index.cjs +132 -0
  61. package/dist/vue/index.cjs.map +1 -0
  62. package/dist/vue/index.d.ts +7 -0
  63. package/dist/vue/index.d.ts.map +1 -0
  64. package/dist/vue/index.js +115 -0
  65. package/dist/vue/index.js.map +1 -0
  66. package/package.json +144 -0
@@ -0,0 +1,310 @@
1
+ 'use strict';
2
+
3
+ var zod = require('zod');
4
+
5
+ // src/core/errors.ts
6
+ var MemoryIntelligenceError = class extends Error {
7
+ constructor(message) {
8
+ super(message);
9
+ this.name = "MemoryIntelligenceError";
10
+ }
11
+ };
12
+ var ConfigurationError = class extends MemoryIntelligenceError {
13
+ constructor(message) {
14
+ super(message);
15
+ this.name = "ConfigurationError";
16
+ }
17
+ };
18
+ var MemoryNotFoundError = class extends MemoryIntelligenceError {
19
+ constructor(memoryId) {
20
+ super(`Memory not found: ${memoryId}`);
21
+ this.name = "MemoryNotFoundError";
22
+ }
23
+ };
24
+ var DatabaseError = class extends MemoryIntelligenceError {
25
+ constructor(message, originalError) {
26
+ super(message);
27
+ this.originalError = originalError;
28
+ this.name = "DatabaseError";
29
+ }
30
+ };
31
+ var EmbeddingError = class extends MemoryIntelligenceError {
32
+ constructor(message, originalError) {
33
+ super(message);
34
+ this.originalError = originalError;
35
+ this.name = "EmbeddingError";
36
+ }
37
+ };
38
+ var ValidationError = class extends MemoryIntelligenceError {
39
+ constructor(message) {
40
+ super(message);
41
+ this.name = "ValidationError";
42
+ }
43
+ };
44
+
45
+ // src/utils/http-client.ts
46
+ var HttpClient = class {
47
+ apiUrl;
48
+ apiKey;
49
+ timeout;
50
+ headers;
51
+ constructor(config) {
52
+ if (!config.apiKey) {
53
+ throw new ConfigurationError("API key is required");
54
+ }
55
+ if (!config.apiKey.startsWith("lano_")) {
56
+ throw new ConfigurationError(
57
+ "Invalid API key format. API key should start with 'lano_'"
58
+ );
59
+ }
60
+ this.apiUrl = config.apiUrl.replace(/\/$/, "");
61
+ this.apiKey = config.apiKey;
62
+ this.timeout = config.timeout || 3e4;
63
+ this.headers = {
64
+ "Content-Type": "application/json",
65
+ "X-API-Key": this.apiKey,
66
+ ...config.headers
67
+ };
68
+ }
69
+ async request(method, endpoint, data) {
70
+ const url = `${this.apiUrl}${endpoint}`;
71
+ const controller = new AbortController();
72
+ const timeoutId = setTimeout(() => controller.abort(), this.timeout);
73
+ try {
74
+ const options = {
75
+ method,
76
+ headers: this.headers,
77
+ signal: controller.signal
78
+ };
79
+ if (data && (method === "POST" || method === "PUT" || method === "PATCH")) {
80
+ options.body = JSON.stringify(data);
81
+ }
82
+ const response = await fetch(url, options);
83
+ clearTimeout(timeoutId);
84
+ const responseData = await response.json();
85
+ if (!response.ok) {
86
+ return {
87
+ status: response.status,
88
+ error: {
89
+ message: responseData?.message || responseData?.error || "Request failed",
90
+ code: responseData?.code
91
+ }
92
+ };
93
+ }
94
+ return {
95
+ status: response.status,
96
+ data: responseData
97
+ };
98
+ } catch (error) {
99
+ clearTimeout(timeoutId);
100
+ if (error instanceof Error) {
101
+ if (error.name === "AbortError") {
102
+ return {
103
+ status: 408,
104
+ error: {
105
+ message: `Request timeout after ${this.timeout}ms`,
106
+ code: "TIMEOUT"
107
+ }
108
+ };
109
+ }
110
+ return {
111
+ status: 0,
112
+ error: {
113
+ message: error.message,
114
+ code: "NETWORK_ERROR"
115
+ }
116
+ };
117
+ }
118
+ return {
119
+ status: 0,
120
+ error: {
121
+ message: "Unknown error occurred",
122
+ code: "UNKNOWN_ERROR"
123
+ }
124
+ };
125
+ }
126
+ }
127
+ async get(endpoint) {
128
+ return this.request("GET", endpoint);
129
+ }
130
+ async post(endpoint, data) {
131
+ return this.request("POST", endpoint, data);
132
+ }
133
+ async put(endpoint, data) {
134
+ return this.request("PUT", endpoint, data);
135
+ }
136
+ async patch(endpoint, data) {
137
+ return this.request("PATCH", endpoint, data);
138
+ }
139
+ async delete(endpoint) {
140
+ return this.request("DELETE", endpoint);
141
+ }
142
+ };
143
+
144
+ // src/core/client.ts
145
+ var DEFAULT_API_URL = "https://api.lanonasis.com/api/v1";
146
+ var MemoryIntelligenceClient = class {
147
+ httpClient;
148
+ defaultResponseFormat;
149
+ constructor(config) {
150
+ if (!config.apiKey) {
151
+ throw new ConfigurationError(
152
+ "Missing required configuration: apiKey is required (format: lano_xxxxxxxxxx)"
153
+ );
154
+ }
155
+ this.httpClient = new HttpClient({
156
+ apiUrl: config.apiUrl || DEFAULT_API_URL,
157
+ apiKey: config.apiKey,
158
+ timeout: config.timeout,
159
+ headers: config.headers
160
+ });
161
+ this.defaultResponseFormat = config.responseFormat || "markdown";
162
+ }
163
+ /**
164
+ * Get HTTP client for direct API access
165
+ */
166
+ getHttpClient() {
167
+ return this.httpClient;
168
+ }
169
+ /**
170
+ * Query memories from the API
171
+ */
172
+ async queryMemories(userId, options = {}) {
173
+ const { type, limit = 100, offset = 0 } = options;
174
+ const params = new URLSearchParams({
175
+ user_id: userId,
176
+ limit: limit.toString(),
177
+ offset: offset.toString()
178
+ });
179
+ if (type) {
180
+ params.append("type", type);
181
+ }
182
+ const response = await this.httpClient.get(
183
+ `/intelligence/memories?${params.toString()}`
184
+ );
185
+ if (response.error) {
186
+ throw new DatabaseError(`Failed to query memories: ${response.error.message}`);
187
+ }
188
+ return response.data?.memories || [];
189
+ }
190
+ /**
191
+ * Analyze usage patterns and trends in memory collection
192
+ */
193
+ async analyzePatterns(params) {
194
+ const response = await this.httpClient.post(
195
+ "/intelligence/analyze-patterns",
196
+ {
197
+ ...params,
198
+ responseFormat: params.responseFormat || this.defaultResponseFormat
199
+ }
200
+ );
201
+ if (response.error) {
202
+ throw new DatabaseError(`Failed to analyze patterns: ${response.error.message}`);
203
+ }
204
+ return response.data;
205
+ }
206
+ /**
207
+ * Get AI-powered tag suggestions for a memory
208
+ */
209
+ async suggestTags(params) {
210
+ const response = await this.httpClient.post(
211
+ "/intelligence/suggest-tags",
212
+ {
213
+ ...params,
214
+ responseFormat: params.responseFormat || this.defaultResponseFormat
215
+ }
216
+ );
217
+ if (response.error) {
218
+ throw new DatabaseError(`Failed to suggest tags: ${response.error.message}`);
219
+ }
220
+ return response.data;
221
+ }
222
+ /**
223
+ * Find semantically related memories using vector similarity
224
+ */
225
+ async findRelated(params) {
226
+ const response = await this.httpClient.post(
227
+ "/intelligence/find-related",
228
+ {
229
+ ...params,
230
+ responseFormat: params.responseFormat || this.defaultResponseFormat
231
+ }
232
+ );
233
+ if (response.error) {
234
+ throw new DatabaseError(`Failed to find related memories: ${response.error.message}`);
235
+ }
236
+ return response.data;
237
+ }
238
+ /**
239
+ * Detect potential duplicate memories
240
+ */
241
+ async detectDuplicates(params) {
242
+ const response = await this.httpClient.post(
243
+ "/intelligence/detect-duplicates",
244
+ {
245
+ ...params,
246
+ responseFormat: params.responseFormat || this.defaultResponseFormat
247
+ }
248
+ );
249
+ if (response.error) {
250
+ throw new DatabaseError(`Failed to detect duplicates: ${response.error.message}`);
251
+ }
252
+ return response.data;
253
+ }
254
+ /**
255
+ * Extract insights and patterns from memories
256
+ */
257
+ async extractInsights(params) {
258
+ const response = await this.httpClient.post(
259
+ "/intelligence/extract-insights",
260
+ {
261
+ ...params,
262
+ responseFormat: params.responseFormat || this.defaultResponseFormat
263
+ }
264
+ );
265
+ if (response.error) {
266
+ throw new DatabaseError(`Failed to extract insights: ${response.error.message}`);
267
+ }
268
+ return response.data;
269
+ }
270
+ /**
271
+ * Check the health and organization quality of memories
272
+ */
273
+ async healthCheck(params) {
274
+ const response = await this.httpClient.post(
275
+ "/intelligence/health-check",
276
+ {
277
+ ...params,
278
+ responseFormat: params.responseFormat || this.defaultResponseFormat
279
+ }
280
+ );
281
+ if (response.error) {
282
+ throw new DatabaseError(`Failed to check health: ${response.error.message}`);
283
+ }
284
+ return response.data;
285
+ }
286
+ };
287
+ var ResponseFormat = {
288
+ JSON: "json",
289
+ MARKDOWN: "markdown"
290
+ };
291
+ var MemoryType = zod.z.enum([
292
+ "context",
293
+ "project",
294
+ "knowledge",
295
+ "reference",
296
+ "personal",
297
+ "workflow"
298
+ ]);
299
+
300
+ exports.ConfigurationError = ConfigurationError;
301
+ exports.DatabaseError = DatabaseError;
302
+ exports.EmbeddingError = EmbeddingError;
303
+ exports.MemoryIntelligenceClient = MemoryIntelligenceClient;
304
+ exports.MemoryIntelligenceError = MemoryIntelligenceError;
305
+ exports.MemoryNotFoundError = MemoryNotFoundError;
306
+ exports.MemoryType = MemoryType;
307
+ exports.ResponseFormat = ResponseFormat;
308
+ exports.ValidationError = ValidationError;
309
+ //# sourceMappingURL=index.cjs.map
310
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/core/errors.ts","../../src/utils/http-client.ts","../../src/core/client.ts","../../src/core/types.ts"],"names":["z"],"mappings":"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","file":"index.cjs","sourcesContent":["/**\n * SDK-specific error classes\n */\n\nexport class MemoryIntelligenceError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"MemoryIntelligenceError\";\n }\n}\n\nexport class ConfigurationError extends MemoryIntelligenceError {\n constructor(message: string) {\n super(message);\n this.name = \"ConfigurationError\";\n }\n}\n\nexport class MemoryNotFoundError extends MemoryIntelligenceError {\n constructor(memoryId: string) {\n super(`Memory not found: ${memoryId}`);\n this.name = \"MemoryNotFoundError\";\n }\n}\n\nexport class DatabaseError extends MemoryIntelligenceError {\n constructor(message: string, public originalError?: Error) {\n super(message);\n this.name = \"DatabaseError\";\n }\n}\n\nexport class EmbeddingError extends MemoryIntelligenceError {\n constructor(message: string, public originalError?: Error) {\n super(message);\n this.name = \"EmbeddingError\";\n }\n}\n\nexport class ValidationError extends MemoryIntelligenceError {\n constructor(message: string) {\n super(message);\n this.name = \"ValidationError\";\n }\n}\n","/**\n * HTTP client for Lanonasis API\n */\n\nimport { ConfigurationError } from \"../core/errors\";\n\nexport interface HttpClientConfig {\n apiUrl: string;\n apiKey: string;\n timeout?: number;\n headers?: Record<string, string>;\n}\n\nexport interface ApiResponse<T = any> {\n data?: T;\n error?: {\n message: string;\n code?: string;\n };\n status: number;\n}\n\nexport class HttpClient {\n private apiUrl: string;\n private apiKey: string;\n private timeout: number;\n private headers: Record<string, string>;\n\n constructor(config: HttpClientConfig) {\n if (!config.apiKey) {\n throw new ConfigurationError(\"API key is required\");\n }\n\n if (!config.apiKey.startsWith(\"lano_\")) {\n throw new ConfigurationError(\n \"Invalid API key format. API key should start with 'lano_'\"\n );\n }\n\n this.apiUrl = config.apiUrl.replace(/\\/$/, \"\"); // Remove trailing slash\n this.apiKey = config.apiKey;\n this.timeout = config.timeout || 30000;\n this.headers = {\n \"Content-Type\": \"application/json\",\n \"X-API-Key\": this.apiKey,\n ...config.headers,\n };\n }\n\n private async request<T>(\n method: string,\n endpoint: string,\n data?: any\n ): Promise<ApiResponse<T>> {\n const url = `${this.apiUrl}${endpoint}`;\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), this.timeout);\n\n try {\n const options: RequestInit = {\n method,\n headers: this.headers,\n signal: controller.signal,\n };\n\n if (data && (method === \"POST\" || method === \"PUT\" || method === \"PATCH\")) {\n options.body = JSON.stringify(data);\n }\n\n const response = await fetch(url, options);\n clearTimeout(timeoutId);\n\n const responseData = await response.json() as any;\n\n if (!response.ok) {\n return {\n status: response.status,\n error: {\n message: responseData?.message || responseData?.error || \"Request failed\",\n code: responseData?.code,\n },\n };\n }\n\n return {\n status: response.status,\n data: responseData as T,\n };\n } catch (error) {\n clearTimeout(timeoutId);\n\n if (error instanceof Error) {\n if (error.name === \"AbortError\") {\n return {\n status: 408,\n error: {\n message: `Request timeout after ${this.timeout}ms`,\n code: \"TIMEOUT\",\n },\n };\n }\n\n return {\n status: 0,\n error: {\n message: error.message,\n code: \"NETWORK_ERROR\",\n },\n };\n }\n\n return {\n status: 0,\n error: {\n message: \"Unknown error occurred\",\n code: \"UNKNOWN_ERROR\",\n },\n };\n }\n }\n\n async get<T>(endpoint: string): Promise<ApiResponse<T>> {\n return this.request<T>(\"GET\", endpoint);\n }\n\n async post<T>(endpoint: string, data?: any): Promise<ApiResponse<T>> {\n return this.request<T>(\"POST\", endpoint, data);\n }\n\n async put<T>(endpoint: string, data?: any): Promise<ApiResponse<T>> {\n return this.request<T>(\"PUT\", endpoint, data);\n }\n\n async patch<T>(endpoint: string, data?: any): Promise<ApiResponse<T>> {\n return this.request<T>(\"PATCH\", endpoint, data);\n }\n\n async delete<T>(endpoint: string): Promise<ApiResponse<T>> {\n return this.request<T>(\"DELETE\", endpoint);\n }\n}\n","/**\n * Core Memory Intelligence Client\n */\n\nimport {\n MemoryIntelligenceConfig,\n AnalyzePatternsParams,\n PatternAnalysis,\n SuggestTagsParams,\n TagSuggestionsResult,\n FindRelatedParams,\n RelatedMemoriesResult,\n DetectDuplicatesParams,\n DuplicatesResult,\n ExtractInsightsParams,\n InsightsResult,\n HealthCheckParams,\n MemoryHealth,\n QueryMemoriesOptions,\n MemoryEntry,\n} from \"./types\";\nimport { ConfigurationError, DatabaseError } from \"./errors\";\nimport { HttpClient } from \"../utils/http-client\";\n\nconst DEFAULT_API_URL = \"https://api.lanonasis.com/api/v1\";\n\nexport class MemoryIntelligenceClient {\n private httpClient: HttpClient;\n private defaultResponseFormat: \"json\" | \"markdown\";\n\n constructor(config: MemoryIntelligenceConfig) {\n // Validate configuration\n if (!config.apiKey) {\n throw new ConfigurationError(\n \"Missing required configuration: apiKey is required (format: lano_xxxxxxxxxx)\"\n );\n }\n\n this.httpClient = new HttpClient({\n apiUrl: config.apiUrl || DEFAULT_API_URL,\n apiKey: config.apiKey,\n timeout: config.timeout,\n headers: config.headers,\n });\n\n this.defaultResponseFormat = config.responseFormat || \"markdown\";\n }\n\n /**\n * Get HTTP client for direct API access\n */\n public getHttpClient(): HttpClient {\n return this.httpClient;\n }\n\n /**\n * Query memories from the API\n */\n public async queryMemories(\n userId: string,\n options: QueryMemoriesOptions = {}\n ): Promise<MemoryEntry[]> {\n const { type, limit = 100, offset = 0 } = options;\n\n const params = new URLSearchParams({\n user_id: userId,\n limit: limit.toString(),\n offset: offset.toString(),\n });\n\n if (type) {\n params.append(\"type\", type);\n }\n\n const response = await this.httpClient.get<{ memories: MemoryEntry[] }>(\n `/intelligence/memories?${params.toString()}`\n );\n\n if (response.error) {\n throw new DatabaseError(`Failed to query memories: ${response.error.message}`);\n }\n\n return response.data?.memories || [];\n }\n\n /**\n * Analyze usage patterns and trends in memory collection\n */\n async analyzePatterns(params: AnalyzePatternsParams): Promise<PatternAnalysis> {\n const response = await this.httpClient.post<PatternAnalysis>(\n \"/intelligence/analyze-patterns\",\n {\n ...params,\n responseFormat: params.responseFormat || this.defaultResponseFormat,\n }\n );\n\n if (response.error) {\n throw new DatabaseError(`Failed to analyze patterns: ${response.error.message}`);\n }\n\n return response.data!;\n }\n\n /**\n * Get AI-powered tag suggestions for a memory\n */\n async suggestTags(params: SuggestTagsParams): Promise<TagSuggestionsResult> {\n const response = await this.httpClient.post<TagSuggestionsResult>(\n \"/intelligence/suggest-tags\",\n {\n ...params,\n responseFormat: params.responseFormat || this.defaultResponseFormat,\n }\n );\n\n if (response.error) {\n throw new DatabaseError(`Failed to suggest tags: ${response.error.message}`);\n }\n\n return response.data!;\n }\n\n /**\n * Find semantically related memories using vector similarity\n */\n async findRelated(params: FindRelatedParams): Promise<RelatedMemoriesResult> {\n const response = await this.httpClient.post<RelatedMemoriesResult>(\n \"/intelligence/find-related\",\n {\n ...params,\n responseFormat: params.responseFormat || this.defaultResponseFormat,\n }\n );\n\n if (response.error) {\n throw new DatabaseError(`Failed to find related memories: ${response.error.message}`);\n }\n\n return response.data!;\n }\n\n /**\n * Detect potential duplicate memories\n */\n async detectDuplicates(params: DetectDuplicatesParams): Promise<DuplicatesResult> {\n const response = await this.httpClient.post<DuplicatesResult>(\n \"/intelligence/detect-duplicates\",\n {\n ...params,\n responseFormat: params.responseFormat || this.defaultResponseFormat,\n }\n );\n\n if (response.error) {\n throw new DatabaseError(`Failed to detect duplicates: ${response.error.message}`);\n }\n\n return response.data!;\n }\n\n /**\n * Extract insights and patterns from memories\n */\n async extractInsights(params: ExtractInsightsParams): Promise<InsightsResult> {\n const response = await this.httpClient.post<InsightsResult>(\n \"/intelligence/extract-insights\",\n {\n ...params,\n responseFormat: params.responseFormat || this.defaultResponseFormat,\n }\n );\n\n if (response.error) {\n throw new DatabaseError(`Failed to extract insights: ${response.error.message}`);\n }\n\n return response.data!;\n }\n\n /**\n * Check the health and organization quality of memories\n */\n async healthCheck(params: HealthCheckParams): Promise<MemoryHealth> {\n const response = await this.httpClient.post<MemoryHealth>(\n \"/intelligence/health-check\",\n {\n ...params,\n responseFormat: params.responseFormat || this.defaultResponseFormat,\n }\n );\n\n if (response.error) {\n throw new DatabaseError(`Failed to check health: ${response.error.message}`);\n }\n\n return response.data!;\n }\n}\n","/**\n * Type definitions for Memory Intelligence SDK\n */\n\nimport { z } from \"zod\";\n\n// Response format enum\nexport const ResponseFormat = {\n JSON: \"json\",\n MARKDOWN: \"markdown\",\n} as const;\n\nexport type ResponseFormatType = (typeof ResponseFormat)[keyof typeof ResponseFormat];\n\n// Memory type enum\nexport const MemoryType = z.enum([\n \"context\",\n \"project\",\n \"knowledge\",\n \"reference\",\n \"personal\",\n \"workflow\",\n]);\n\nexport type MemoryTypeValue = z.infer<typeof MemoryType>;\n\n// Configuration interface\nexport interface MemoryIntelligenceConfig {\n apiUrl?: string; // Lanonasis API URL (default: https://api.lanonasis.com/api/v1)\n apiKey: string; // Lanonasis API key (format: lano_xxxxxxxxxx)\n timeout?: number; // Request timeout in milliseconds (default: 30000)\n responseFormat?: ResponseFormatType;\n headers?: Record<string, string>; // Custom headers\n}\n\n// Tool parameter interfaces\nexport interface AnalyzePatternsParams {\n userId: string;\n timeRangeDays?: number;\n responseFormat?: ResponseFormatType;\n}\n\nexport interface SuggestTagsParams {\n memoryId: string;\n userId: string;\n maxSuggestions?: number;\n includeExistingTags?: boolean;\n responseFormat?: ResponseFormatType;\n}\n\nexport interface FindRelatedParams {\n memoryId: string;\n userId: string;\n limit?: number;\n similarityThreshold?: number;\n responseFormat?: ResponseFormatType;\n}\n\nexport interface DetectDuplicatesParams {\n userId: string;\n similarityThreshold?: number;\n maxPairs?: number;\n responseFormat?: ResponseFormatType;\n}\n\nexport interface ExtractInsightsParams {\n userId: string;\n topic?: string;\n memoryType?: MemoryTypeValue;\n maxMemories?: number;\n responseFormat?: ResponseFormatType;\n}\n\nexport interface HealthCheckParams {\n userId: string;\n responseFormat?: ResponseFormatType;\n}\n\n// Tool result interfaces\nexport interface PatternAnalysis {\n total_memories: number;\n memories_by_type: Record<string, number>;\n memories_by_day_of_week: Record<string, number>;\n peak_creation_hours: number[];\n average_content_length: number;\n most_common_tags: Array<{ tag: string; count: number }>;\n creation_velocity: {\n daily_average: number;\n trend: \"increasing\" | \"stable\" | \"decreasing\";\n };\n insights: string[];\n}\n\nexport interface TagSuggestion {\n tag: string;\n confidence: number;\n reasoning: string;\n}\n\nexport interface TagSuggestionsResult {\n memory_id: string;\n existing_tags: string[];\n suggestions: TagSuggestion[];\n context: {\n memory_type: string;\n related_memories_analyzed: number;\n };\n}\n\nexport interface RelatedMemory {\n id: string;\n title: string;\n type: string;\n similarity_score: number;\n shared_tags: string[];\n content_preview: string;\n}\n\nexport interface RelatedMemoriesResult {\n source_memory: {\n id: string;\n title: string;\n type: string;\n };\n related_memories: RelatedMemory[];\n total_found: number;\n}\n\nexport interface DuplicatePair {\n memory_1: {\n id: string;\n title: string;\n created_at: string;\n };\n memory_2: {\n id: string;\n title: string;\n created_at: string;\n };\n similarity_score: number;\n recommendation: \"keep_newer\" | \"keep_older\" | \"merge\" | \"review_manually\";\n reasoning: string;\n}\n\nexport interface DuplicatesResult {\n total_memories_analyzed: number;\n duplicate_pairs_found: number;\n duplicate_pairs: DuplicatePair[];\n estimated_storage_savings: string;\n}\n\nexport interface Insight {\n category: \"pattern\" | \"learning\" | \"opportunity\" | \"risk\" | \"action_item\";\n title: string;\n description: string;\n confidence: number;\n supporting_memories: string[];\n}\n\nexport interface InsightsResult {\n total_memories_analyzed: number;\n insights: Insight[];\n summary: string;\n topic_filter?: string;\n type_filter?: string;\n}\n\nexport interface MemoryHealth {\n user_id: string;\n health_score: number;\n metrics: {\n total_memories: number;\n memories_with_embeddings: number;\n embedding_coverage_percentage: number;\n memories_with_tags: number;\n tagging_percentage: number;\n average_tags_per_memory: number;\n memories_by_type: Record<string, number>;\n };\n issues: string[];\n recommendations: string[];\n analysis_date: string;\n}\n\n// Memory entry interface (from database)\nexport interface MemoryEntry {\n id: string;\n user_id: string;\n title: string;\n content: string;\n type: MemoryTypeValue;\n tags?: string[];\n metadata?: Record<string, any>;\n embedding?: number[];\n created_at: string;\n updated_at: string;\n}\n\n// Query options for internal use\nexport interface QueryMemoriesOptions {\n type?: string;\n limit?: number;\n offset?: number;\n includeEmbeddings?: boolean;\n}\n"]}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Core module barrel export
3
+ */
4
+ export { MemoryIntelligenceClient } from "./client";
5
+ export * from "./types";
6
+ export * from "./errors";
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,wBAAwB,EAAE,MAAM,UAAU,CAAC;AACpD,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC"}
@@ -0,0 +1,300 @@
1
+ import { z } from 'zod';
2
+
3
+ // src/core/errors.ts
4
+ var MemoryIntelligenceError = class extends Error {
5
+ constructor(message) {
6
+ super(message);
7
+ this.name = "MemoryIntelligenceError";
8
+ }
9
+ };
10
+ var ConfigurationError = class extends MemoryIntelligenceError {
11
+ constructor(message) {
12
+ super(message);
13
+ this.name = "ConfigurationError";
14
+ }
15
+ };
16
+ var MemoryNotFoundError = class extends MemoryIntelligenceError {
17
+ constructor(memoryId) {
18
+ super(`Memory not found: ${memoryId}`);
19
+ this.name = "MemoryNotFoundError";
20
+ }
21
+ };
22
+ var DatabaseError = class extends MemoryIntelligenceError {
23
+ constructor(message, originalError) {
24
+ super(message);
25
+ this.originalError = originalError;
26
+ this.name = "DatabaseError";
27
+ }
28
+ };
29
+ var EmbeddingError = class extends MemoryIntelligenceError {
30
+ constructor(message, originalError) {
31
+ super(message);
32
+ this.originalError = originalError;
33
+ this.name = "EmbeddingError";
34
+ }
35
+ };
36
+ var ValidationError = class extends MemoryIntelligenceError {
37
+ constructor(message) {
38
+ super(message);
39
+ this.name = "ValidationError";
40
+ }
41
+ };
42
+
43
+ // src/utils/http-client.ts
44
+ var HttpClient = class {
45
+ apiUrl;
46
+ apiKey;
47
+ timeout;
48
+ headers;
49
+ constructor(config) {
50
+ if (!config.apiKey) {
51
+ throw new ConfigurationError("API key is required");
52
+ }
53
+ if (!config.apiKey.startsWith("lano_")) {
54
+ throw new ConfigurationError(
55
+ "Invalid API key format. API key should start with 'lano_'"
56
+ );
57
+ }
58
+ this.apiUrl = config.apiUrl.replace(/\/$/, "");
59
+ this.apiKey = config.apiKey;
60
+ this.timeout = config.timeout || 3e4;
61
+ this.headers = {
62
+ "Content-Type": "application/json",
63
+ "X-API-Key": this.apiKey,
64
+ ...config.headers
65
+ };
66
+ }
67
+ async request(method, endpoint, data) {
68
+ const url = `${this.apiUrl}${endpoint}`;
69
+ const controller = new AbortController();
70
+ const timeoutId = setTimeout(() => controller.abort(), this.timeout);
71
+ try {
72
+ const options = {
73
+ method,
74
+ headers: this.headers,
75
+ signal: controller.signal
76
+ };
77
+ if (data && (method === "POST" || method === "PUT" || method === "PATCH")) {
78
+ options.body = JSON.stringify(data);
79
+ }
80
+ const response = await fetch(url, options);
81
+ clearTimeout(timeoutId);
82
+ const responseData = await response.json();
83
+ if (!response.ok) {
84
+ return {
85
+ status: response.status,
86
+ error: {
87
+ message: responseData?.message || responseData?.error || "Request failed",
88
+ code: responseData?.code
89
+ }
90
+ };
91
+ }
92
+ return {
93
+ status: response.status,
94
+ data: responseData
95
+ };
96
+ } catch (error) {
97
+ clearTimeout(timeoutId);
98
+ if (error instanceof Error) {
99
+ if (error.name === "AbortError") {
100
+ return {
101
+ status: 408,
102
+ error: {
103
+ message: `Request timeout after ${this.timeout}ms`,
104
+ code: "TIMEOUT"
105
+ }
106
+ };
107
+ }
108
+ return {
109
+ status: 0,
110
+ error: {
111
+ message: error.message,
112
+ code: "NETWORK_ERROR"
113
+ }
114
+ };
115
+ }
116
+ return {
117
+ status: 0,
118
+ error: {
119
+ message: "Unknown error occurred",
120
+ code: "UNKNOWN_ERROR"
121
+ }
122
+ };
123
+ }
124
+ }
125
+ async get(endpoint) {
126
+ return this.request("GET", endpoint);
127
+ }
128
+ async post(endpoint, data) {
129
+ return this.request("POST", endpoint, data);
130
+ }
131
+ async put(endpoint, data) {
132
+ return this.request("PUT", endpoint, data);
133
+ }
134
+ async patch(endpoint, data) {
135
+ return this.request("PATCH", endpoint, data);
136
+ }
137
+ async delete(endpoint) {
138
+ return this.request("DELETE", endpoint);
139
+ }
140
+ };
141
+
142
+ // src/core/client.ts
143
+ var DEFAULT_API_URL = "https://api.lanonasis.com/api/v1";
144
+ var MemoryIntelligenceClient = class {
145
+ httpClient;
146
+ defaultResponseFormat;
147
+ constructor(config) {
148
+ if (!config.apiKey) {
149
+ throw new ConfigurationError(
150
+ "Missing required configuration: apiKey is required (format: lano_xxxxxxxxxx)"
151
+ );
152
+ }
153
+ this.httpClient = new HttpClient({
154
+ apiUrl: config.apiUrl || DEFAULT_API_URL,
155
+ apiKey: config.apiKey,
156
+ timeout: config.timeout,
157
+ headers: config.headers
158
+ });
159
+ this.defaultResponseFormat = config.responseFormat || "markdown";
160
+ }
161
+ /**
162
+ * Get HTTP client for direct API access
163
+ */
164
+ getHttpClient() {
165
+ return this.httpClient;
166
+ }
167
+ /**
168
+ * Query memories from the API
169
+ */
170
+ async queryMemories(userId, options = {}) {
171
+ const { type, limit = 100, offset = 0 } = options;
172
+ const params = new URLSearchParams({
173
+ user_id: userId,
174
+ limit: limit.toString(),
175
+ offset: offset.toString()
176
+ });
177
+ if (type) {
178
+ params.append("type", type);
179
+ }
180
+ const response = await this.httpClient.get(
181
+ `/intelligence/memories?${params.toString()}`
182
+ );
183
+ if (response.error) {
184
+ throw new DatabaseError(`Failed to query memories: ${response.error.message}`);
185
+ }
186
+ return response.data?.memories || [];
187
+ }
188
+ /**
189
+ * Analyze usage patterns and trends in memory collection
190
+ */
191
+ async analyzePatterns(params) {
192
+ const response = await this.httpClient.post(
193
+ "/intelligence/analyze-patterns",
194
+ {
195
+ ...params,
196
+ responseFormat: params.responseFormat || this.defaultResponseFormat
197
+ }
198
+ );
199
+ if (response.error) {
200
+ throw new DatabaseError(`Failed to analyze patterns: ${response.error.message}`);
201
+ }
202
+ return response.data;
203
+ }
204
+ /**
205
+ * Get AI-powered tag suggestions for a memory
206
+ */
207
+ async suggestTags(params) {
208
+ const response = await this.httpClient.post(
209
+ "/intelligence/suggest-tags",
210
+ {
211
+ ...params,
212
+ responseFormat: params.responseFormat || this.defaultResponseFormat
213
+ }
214
+ );
215
+ if (response.error) {
216
+ throw new DatabaseError(`Failed to suggest tags: ${response.error.message}`);
217
+ }
218
+ return response.data;
219
+ }
220
+ /**
221
+ * Find semantically related memories using vector similarity
222
+ */
223
+ async findRelated(params) {
224
+ const response = await this.httpClient.post(
225
+ "/intelligence/find-related",
226
+ {
227
+ ...params,
228
+ responseFormat: params.responseFormat || this.defaultResponseFormat
229
+ }
230
+ );
231
+ if (response.error) {
232
+ throw new DatabaseError(`Failed to find related memories: ${response.error.message}`);
233
+ }
234
+ return response.data;
235
+ }
236
+ /**
237
+ * Detect potential duplicate memories
238
+ */
239
+ async detectDuplicates(params) {
240
+ const response = await this.httpClient.post(
241
+ "/intelligence/detect-duplicates",
242
+ {
243
+ ...params,
244
+ responseFormat: params.responseFormat || this.defaultResponseFormat
245
+ }
246
+ );
247
+ if (response.error) {
248
+ throw new DatabaseError(`Failed to detect duplicates: ${response.error.message}`);
249
+ }
250
+ return response.data;
251
+ }
252
+ /**
253
+ * Extract insights and patterns from memories
254
+ */
255
+ async extractInsights(params) {
256
+ const response = await this.httpClient.post(
257
+ "/intelligence/extract-insights",
258
+ {
259
+ ...params,
260
+ responseFormat: params.responseFormat || this.defaultResponseFormat
261
+ }
262
+ );
263
+ if (response.error) {
264
+ throw new DatabaseError(`Failed to extract insights: ${response.error.message}`);
265
+ }
266
+ return response.data;
267
+ }
268
+ /**
269
+ * Check the health and organization quality of memories
270
+ */
271
+ async healthCheck(params) {
272
+ const response = await this.httpClient.post(
273
+ "/intelligence/health-check",
274
+ {
275
+ ...params,
276
+ responseFormat: params.responseFormat || this.defaultResponseFormat
277
+ }
278
+ );
279
+ if (response.error) {
280
+ throw new DatabaseError(`Failed to check health: ${response.error.message}`);
281
+ }
282
+ return response.data;
283
+ }
284
+ };
285
+ var ResponseFormat = {
286
+ JSON: "json",
287
+ MARKDOWN: "markdown"
288
+ };
289
+ var MemoryType = z.enum([
290
+ "context",
291
+ "project",
292
+ "knowledge",
293
+ "reference",
294
+ "personal",
295
+ "workflow"
296
+ ]);
297
+
298
+ export { ConfigurationError, DatabaseError, EmbeddingError, MemoryIntelligenceClient, MemoryIntelligenceError, MemoryNotFoundError, MemoryType, ResponseFormat, ValidationError };
299
+ //# sourceMappingURL=index.js.map
300
+ //# sourceMappingURL=index.js.map