mem0ai 3.0.0-beta.0 → 3.0.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.mts +11 -3
- package/dist/index.d.ts +11 -3
- package/dist/index.js +43 -13
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +43 -13
- package/dist/index.mjs.map +1 -1
- package/dist/oss/index.d.mts +98 -97
- package/dist/oss/index.d.ts +98 -97
- package/dist/oss/index.js +2954 -1435
- package/dist/oss/index.js.map +1 -1
- package/dist/oss/index.mjs +2954 -1428
- package/dist/oss/index.mjs.map +1 -1
- package/package.json +4 -3
package/dist/index.d.mts
CHANGED
|
@@ -120,6 +120,12 @@ interface AllUsers {
|
|
|
120
120
|
next: any;
|
|
121
121
|
previous: any;
|
|
122
122
|
}
|
|
123
|
+
interface PaginatedMemories {
|
|
124
|
+
count: number;
|
|
125
|
+
next: string | null;
|
|
126
|
+
previous: string | null;
|
|
127
|
+
results: Array<Memory>;
|
|
128
|
+
}
|
|
123
129
|
interface ProjectResponse {
|
|
124
130
|
customInstructions?: string;
|
|
125
131
|
customCategories?: string[];
|
|
@@ -197,8 +203,10 @@ declare class MemoryClient {
|
|
|
197
203
|
timestamp?: number | string;
|
|
198
204
|
}): Promise<Array<Memory>>;
|
|
199
205
|
get(memoryId: string): Promise<Memory>;
|
|
200
|
-
getAll(options?: GetAllMemoryOptions): Promise<
|
|
201
|
-
search(query: string, options?: SearchMemoryOptions): Promise<
|
|
206
|
+
getAll(options?: GetAllMemoryOptions): Promise<PaginatedMemories>;
|
|
207
|
+
search(query: string, options?: SearchMemoryOptions): Promise<{
|
|
208
|
+
results: Array<Memory>;
|
|
209
|
+
}>;
|
|
202
210
|
delete(memoryId: string): Promise<{
|
|
203
211
|
message: string;
|
|
204
212
|
}>;
|
|
@@ -333,4 +341,4 @@ declare class MemoryQuotaExceededError extends MemoryError {
|
|
|
333
341
|
*/
|
|
334
342
|
declare function createExceptionFromResponse(statusCode: number, responseText: string, options?: Omit<MemoryErrorOptions, "suggestion">): MemoryError;
|
|
335
343
|
|
|
336
|
-
export { type AddMemoryOptions, type AllUsers, AuthenticationError, ConfigurationError, type CreateMemoryExportPayload, type DeleteAllMemoryOptions,
|
|
344
|
+
export { type AddMemoryOptions, type AllUsers, AuthenticationError, ConfigurationError, type CreateMemoryExportPayload, type DeleteAllMemoryOptions, Feedback, type FeedbackPayload, type GetAllMemoryOptions, type GetMemoryExportPayload, type Memory, MemoryClient, MemoryError, type MemoryErrorOptions, type MemoryHistory, MemoryNotFoundError, MemoryQuotaExceededError, type MemoryUpdateBody, type Message, type Messages, NetworkError, type ProjectOptions, type ProjectResponse, type PromptUpdatePayload, RateLimitError, type SearchMemoryOptions, type User, ValidationError, type Webhook, type WebhookCreatePayload, WebhookEvent, type WebhookUpdatePayload, createExceptionFromResponse, MemoryClient as default };
|
package/dist/index.d.ts
CHANGED
|
@@ -120,6 +120,12 @@ interface AllUsers {
|
|
|
120
120
|
next: any;
|
|
121
121
|
previous: any;
|
|
122
122
|
}
|
|
123
|
+
interface PaginatedMemories {
|
|
124
|
+
count: number;
|
|
125
|
+
next: string | null;
|
|
126
|
+
previous: string | null;
|
|
127
|
+
results: Array<Memory>;
|
|
128
|
+
}
|
|
123
129
|
interface ProjectResponse {
|
|
124
130
|
customInstructions?: string;
|
|
125
131
|
customCategories?: string[];
|
|
@@ -197,8 +203,10 @@ declare class MemoryClient {
|
|
|
197
203
|
timestamp?: number | string;
|
|
198
204
|
}): Promise<Array<Memory>>;
|
|
199
205
|
get(memoryId: string): Promise<Memory>;
|
|
200
|
-
getAll(options?: GetAllMemoryOptions): Promise<
|
|
201
|
-
search(query: string, options?: SearchMemoryOptions): Promise<
|
|
206
|
+
getAll(options?: GetAllMemoryOptions): Promise<PaginatedMemories>;
|
|
207
|
+
search(query: string, options?: SearchMemoryOptions): Promise<{
|
|
208
|
+
results: Array<Memory>;
|
|
209
|
+
}>;
|
|
202
210
|
delete(memoryId: string): Promise<{
|
|
203
211
|
message: string;
|
|
204
212
|
}>;
|
|
@@ -333,4 +341,4 @@ declare class MemoryQuotaExceededError extends MemoryError {
|
|
|
333
341
|
*/
|
|
334
342
|
declare function createExceptionFromResponse(statusCode: number, responseText: string, options?: Omit<MemoryErrorOptions, "suggestion">): MemoryError;
|
|
335
343
|
|
|
336
|
-
export { type AddMemoryOptions, type AllUsers, AuthenticationError, ConfigurationError, type CreateMemoryExportPayload, type DeleteAllMemoryOptions,
|
|
344
|
+
export { type AddMemoryOptions, type AllUsers, AuthenticationError, ConfigurationError, type CreateMemoryExportPayload, type DeleteAllMemoryOptions, Feedback, type FeedbackPayload, type GetAllMemoryOptions, type GetMemoryExportPayload, type Memory, MemoryClient, MemoryError, type MemoryErrorOptions, type MemoryHistory, MemoryNotFoundError, MemoryQuotaExceededError, type MemoryUpdateBody, type Message, type Messages, NetworkError, type ProjectOptions, type ProjectResponse, type PromptUpdatePayload, RateLimitError, type SearchMemoryOptions, type User, ValidationError, type Webhook, type WebhookCreatePayload, WebhookEvent, type WebhookUpdatePayload, createExceptionFromResponse, MemoryClient as default };
|
package/dist/index.js
CHANGED
|
@@ -252,6 +252,26 @@ function createExceptionFromResponse(statusCode, responseText, options = {}) {
|
|
|
252
252
|
}
|
|
253
253
|
|
|
254
254
|
// src/client/mem0.ts
|
|
255
|
+
var ENTITY_PARAMS = [
|
|
256
|
+
"user_id",
|
|
257
|
+
"agent_id",
|
|
258
|
+
"app_id",
|
|
259
|
+
"run_id",
|
|
260
|
+
"userId",
|
|
261
|
+
"agentId",
|
|
262
|
+
"appId",
|
|
263
|
+
"runId"
|
|
264
|
+
];
|
|
265
|
+
function rejectTopLevelEntityParams(options, methodName) {
|
|
266
|
+
const invalidKeys = Object.keys(options != null ? options : {}).filter(
|
|
267
|
+
(k) => ENTITY_PARAMS.includes(k)
|
|
268
|
+
);
|
|
269
|
+
if (invalidKeys.length > 0) {
|
|
270
|
+
throw new Error(
|
|
271
|
+
`Top-level entity parameters [${invalidKeys.join(", ")}] are not supported in ${methodName}(). Use filters: { user_id: "..." } instead.`
|
|
272
|
+
);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
255
275
|
var APIError = class extends Error {
|
|
256
276
|
constructor(message) {
|
|
257
277
|
super(message);
|
|
@@ -379,7 +399,7 @@ var MemoryClient = class {
|
|
|
379
399
|
const payloadKeys = Object.keys(payload);
|
|
380
400
|
this._captureEvent("add", [payloadKeys]);
|
|
381
401
|
const response = await this._fetchWithErrorHandling(
|
|
382
|
-
`${this.host}/
|
|
402
|
+
`${this.host}/v3/memories/add/`,
|
|
383
403
|
{
|
|
384
404
|
method: "POST",
|
|
385
405
|
headers: this.headers,
|
|
@@ -426,16 +446,16 @@ var MemoryClient = class {
|
|
|
426
446
|
);
|
|
427
447
|
}
|
|
428
448
|
async getAll(options) {
|
|
429
|
-
|
|
449
|
+
rejectTopLevelEntityParams(options, "getAll");
|
|
430
450
|
if (this.telemetryId === "") await this.ping();
|
|
431
451
|
const payloadKeys = Object.keys(options || {});
|
|
432
452
|
this._captureEvent("get_all", [payloadKeys]);
|
|
433
|
-
const { page, pageSize, ...rest } = options != null ? options : {};
|
|
453
|
+
const { page, pageSize, filters, ...rest } = options != null ? options : {};
|
|
434
454
|
const body = {
|
|
435
|
-
|
|
436
|
-
...
|
|
455
|
+
...camelToSnakeKeys(rest),
|
|
456
|
+
...filters && { filters }
|
|
437
457
|
};
|
|
438
|
-
let url = `${this.host}/
|
|
458
|
+
let url = `${this.host}/v3/memories/`;
|
|
439
459
|
if (page && pageSize) {
|
|
440
460
|
url += `?page=${page}&page_size=${pageSize}`;
|
|
441
461
|
}
|
|
@@ -444,27 +464,29 @@ var MemoryClient = class {
|
|
|
444
464
|
headers: this.headers,
|
|
445
465
|
body: JSON.stringify(body)
|
|
446
466
|
});
|
|
447
|
-
return
|
|
467
|
+
return response;
|
|
448
468
|
}
|
|
449
469
|
async search(query, options) {
|
|
450
|
-
|
|
470
|
+
rejectTopLevelEntityParams(options, "search");
|
|
451
471
|
if (this.telemetryId === "") await this.ping();
|
|
452
472
|
const payloadKeys = Object.keys(options || {});
|
|
453
473
|
this._captureEvent("search", [payloadKeys]);
|
|
474
|
+
const { filters, ...rest } = options != null ? options : {};
|
|
454
475
|
const payload = {
|
|
455
476
|
query,
|
|
456
477
|
output_format: "v1.1",
|
|
457
|
-
...camelToSnakeKeys(
|
|
478
|
+
...camelToSnakeKeys(rest),
|
|
479
|
+
...filters && { filters }
|
|
458
480
|
};
|
|
459
481
|
const response = await this._fetchWithErrorHandling(
|
|
460
|
-
`${this.host}/
|
|
482
|
+
`${this.host}/v3/memories/search/`,
|
|
461
483
|
{
|
|
462
484
|
method: "POST",
|
|
463
485
|
headers: this.headers,
|
|
464
486
|
body: JSON.stringify(payload)
|
|
465
487
|
}
|
|
466
488
|
);
|
|
467
|
-
return
|
|
489
|
+
return response;
|
|
468
490
|
}
|
|
469
491
|
async delete(memoryId) {
|
|
470
492
|
if (this.telemetryId === "") await this.ping();
|
|
@@ -724,12 +746,16 @@ var MemoryClient = class {
|
|
|
724
746
|
if (!data.filters || !data.schema) {
|
|
725
747
|
throw new Error("Missing filters or schema");
|
|
726
748
|
}
|
|
749
|
+
const { filters, ...rest } = data;
|
|
727
750
|
const response = await this._fetchWithErrorHandling(
|
|
728
751
|
`${this.host}/v1/exports/`,
|
|
729
752
|
{
|
|
730
753
|
method: "POST",
|
|
731
754
|
headers: this.headers,
|
|
732
|
-
body: JSON.stringify(
|
|
755
|
+
body: JSON.stringify({
|
|
756
|
+
...camelToSnakeKeys(rest),
|
|
757
|
+
filters
|
|
758
|
+
})
|
|
733
759
|
}
|
|
734
760
|
);
|
|
735
761
|
return response;
|
|
@@ -740,12 +766,16 @@ var MemoryClient = class {
|
|
|
740
766
|
if (!data.memoryExportId && !data.filters) {
|
|
741
767
|
throw new Error("Missing memoryExportId or filters");
|
|
742
768
|
}
|
|
769
|
+
const { filters, ...rest } = data;
|
|
743
770
|
const response = await this._fetchWithErrorHandling(
|
|
744
771
|
`${this.host}/v1/exports/get/`,
|
|
745
772
|
{
|
|
746
773
|
method: "POST",
|
|
747
774
|
headers: this.headers,
|
|
748
|
-
body: JSON.stringify(
|
|
775
|
+
body: JSON.stringify({
|
|
776
|
+
...camelToSnakeKeys(rest),
|
|
777
|
+
...filters && { filters }
|
|
778
|
+
})
|
|
749
779
|
}
|
|
750
780
|
);
|
|
751
781
|
return response;
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/client/index.ts","../src/client/mem0.ts","../src/client/telemetry.ts","../src/client/utils.ts","../src/common/exceptions.ts","../src/client/mem0.types.ts"],"sourcesContent":["import { MemoryClient } from \"./mem0\";\nimport type * as MemoryTypes from \"./mem0.types\";\n\n// Re-export all types from mem0.types\nexport type {\n EntityOptions,\n AddMemoryOptions,\n SearchMemoryOptions,\n GetAllMemoryOptions,\n DeleteAllMemoryOptions,\n ProjectOptions,\n Memory,\n MemoryHistory,\n MemoryUpdateBody,\n ProjectResponse,\n PromptUpdatePayload,\n Webhook,\n WebhookCreatePayload,\n WebhookUpdatePayload,\n Messages,\n Message,\n AllUsers,\n User,\n FeedbackPayload,\n CreateMemoryExportPayload,\n GetMemoryExportPayload,\n} from \"./mem0.types\";\n\n// Re-export enums as values (not type-only)\nexport { Feedback, WebhookEvent } from \"./mem0.types\";\n\n// Export the main client\nexport { MemoryClient };\nexport default MemoryClient;\n\n// Export structured exceptions\nexport {\n MemoryError,\n AuthenticationError,\n RateLimitError,\n ValidationError,\n MemoryNotFoundError,\n NetworkError,\n ConfigurationError,\n MemoryQuotaExceededError,\n createExceptionFromResponse,\n} from \"../common/exceptions\";\n\nexport type { MemoryErrorOptions } from \"../common/exceptions\";\n","import axios from \"axios\";\nimport {\n AllUsers,\n ProjectOptions,\n Memory,\n MemoryHistory,\n AddMemoryOptions,\n SearchMemoryOptions,\n GetAllMemoryOptions,\n DeleteAllMemoryOptions,\n MemoryUpdateBody,\n ProjectResponse,\n PromptUpdatePayload,\n Webhook,\n WebhookCreatePayload,\n WebhookUpdatePayload,\n Message,\n FeedbackPayload,\n CreateMemoryExportPayload,\n GetMemoryExportPayload,\n} from \"./mem0.types\";\nimport { captureClientEvent, generateHash } from \"./telemetry\";\nimport { camelToSnake, camelToSnakeKeys, snakeToCamelKeys } from \"./utils\";\nimport { createExceptionFromResponse, MemoryError } from \"../common/exceptions\";\n\nclass APIError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"APIError\";\n }\n}\n\ninterface ClientOptions {\n apiKey: string;\n host?: string;\n}\n\nexport default class MemoryClient {\n apiKey: string;\n host: string;\n private organizationId: string | number | null;\n private projectId: string | number | null;\n headers: Record<string, string>;\n client: any;\n telemetryId: string;\n\n _validateApiKey(): any {\n if (!this.apiKey) {\n throw new Error(\"Mem0 API key is required\");\n }\n if (typeof this.apiKey !== \"string\") {\n throw new Error(\"Mem0 API key must be a string\");\n }\n if (this.apiKey.trim() === \"\") {\n throw new Error(\"Mem0 API key cannot be empty\");\n }\n }\n\n constructor(options: ClientOptions) {\n this.apiKey = options.apiKey;\n this.host = options.host || \"https://api.mem0.ai\";\n this.organizationId = null;\n this.projectId = null;\n\n this.headers = {\n Authorization: `Token ${this.apiKey}`,\n \"Content-Type\": \"application/json\",\n };\n\n this.client = axios.create({\n baseURL: this.host,\n headers: { Authorization: `Token ${this.apiKey}` },\n timeout: 60000,\n });\n\n this._validateApiKey();\n this.telemetryId = \"\";\n this._initializeClient();\n }\n\n private async _initializeClient() {\n try {\n await this.ping();\n\n if (!this.telemetryId) {\n this.telemetryId = generateHash(this.apiKey);\n }\n\n captureClientEvent(\"init\", this, {\n client_type: \"MemoryClient\",\n }).catch((error: any) => {\n console.error(\"Failed to capture event:\", error);\n });\n } catch (error: any) {\n console.error(\"Failed to initialize client:\", error);\n await captureClientEvent(\"init_error\", this, {\n error: error?.message || \"Unknown error\",\n stack: error?.stack || \"No stack trace\",\n });\n }\n }\n\n private _captureEvent(methodName: string, args: any[]) {\n captureClientEvent(methodName, this, {\n success: true,\n args_count: args.length,\n keys: args.length > 0 ? args[0] : [],\n }).catch((error: any) => {\n console.error(\"Failed to capture event:\", error);\n });\n }\n\n async _fetchWithErrorHandling(url: string, options: any): Promise<any> {\n const response = await fetch(url, {\n ...options,\n headers: {\n ...options.headers,\n Authorization: `Token ${this.apiKey}`,\n \"Mem0-User-ID\": this.telemetryId,\n },\n });\n if (!response.ok) {\n const errorData = await response.text();\n throw createExceptionFromResponse(response.status, errorData);\n }\n const jsonResponse = await response.json();\n return snakeToCamelKeys(jsonResponse);\n }\n\n _preparePayload(\n messages: Array<Message>,\n options: Record<string, any>,\n ): object {\n const payload: any = {};\n payload.messages = messages;\n return camelToSnakeKeys({ ...payload, ...options });\n }\n\n _prepareParams(options: Record<string, any>): object {\n return Object.fromEntries(\n Object.entries(options).filter(([_, v]) => v != null),\n );\n }\n\n async ping(): Promise<void> {\n try {\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/ping/`,\n {\n method: \"GET\",\n headers: {\n Authorization: `Token ${this.apiKey}`,\n },\n },\n );\n\n if (!response || typeof response !== \"object\") {\n throw new APIError(\"Invalid response format from ping endpoint\");\n }\n\n if (response.status !== \"ok\") {\n throw new APIError(response.message || \"API Key is invalid\");\n }\n\n const { orgId, projectId, userEmail } = response;\n\n if (orgId) this.organizationId = orgId;\n if (projectId) this.projectId = projectId;\n if (userEmail) this.telemetryId = userEmail;\n } catch (error: any) {\n // Pass through structured exceptions and APIError\n if (error instanceof MemoryError || error instanceof APIError) {\n throw error;\n } else {\n throw new APIError(\n `Failed to ping server: ${error.message || \"Unknown error\"}`,\n );\n }\n }\n }\n\n async add(\n messages: Array<Message>,\n options: AddMemoryOptions & Record<string, any> = {},\n ): Promise<Array<Memory>> {\n if (this.telemetryId === \"\") await this.ping();\n\n const payload = this._preparePayload(messages, options);\n const payloadKeys = Object.keys(payload);\n this._captureEvent(\"add\", [payloadKeys]);\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/memories/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(payload),\n },\n );\n return response;\n }\n\n async update(\n memoryId: string,\n {\n text,\n metadata,\n timestamp,\n }: {\n text?: string;\n metadata?: Record<string, any>;\n timestamp?: number | string;\n },\n ): Promise<Array<Memory>> {\n if (\n text === undefined &&\n metadata === undefined &&\n timestamp === undefined\n ) {\n throw new Error(\n \"At least one of text, metadata, or timestamp must be provided for update.\",\n );\n }\n\n if (this.telemetryId === \"\") await this.ping();\n const payload: Record<string, any> = {};\n if (text !== undefined) payload.text = text;\n if (metadata !== undefined) payload.metadata = metadata;\n if (timestamp !== undefined) payload.timestamp = timestamp;\n\n const payloadKeys = Object.keys(payload);\n this._captureEvent(\"update\", [payloadKeys]);\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/`,\n {\n method: \"PUT\",\n headers: this.headers,\n body: JSON.stringify(payload),\n },\n );\n return response;\n }\n\n async get(memoryId: string): Promise<Memory> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"get\", []);\n return this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/`,\n {\n headers: this.headers,\n },\n );\n }\n\n async getAll(options?: GetAllMemoryOptions): Promise<Array<Memory>> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"get_all\", [payloadKeys]);\n const { page, pageSize, ...rest } = options ?? {};\n const body: Record<string, any> = {\n output_format: \"v1.1\",\n ...camelToSnakeKeys(rest),\n };\n\n let url = `${this.host}/v2/memories/`;\n if (page && pageSize) {\n url += `?page=${page}&page_size=${pageSize}`;\n }\n\n const response = await this._fetchWithErrorHandling(url, {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(body),\n });\n // Unwrap v1.1 format: { results: [...] } → [...]\n return Array.isArray(response) ? response : (response?.results ?? response);\n }\n\n async search(\n query: string,\n options?: SearchMemoryOptions,\n ): Promise<Array<Memory>> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"search\", [payloadKeys]);\n const payload: Record<string, any> = {\n query,\n output_format: \"v1.1\",\n ...camelToSnakeKeys(options ?? {}),\n };\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v2/memories/search/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(payload),\n },\n );\n // Unwrap v1.1 format: { results: [...] } → [...]\n return Array.isArray(response) ? response : (response?.results ?? response);\n }\n\n async delete(memoryId: string): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"delete\", []);\n return this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n }\n\n async deleteAll(\n options: DeleteAllMemoryOptions = {},\n ): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"delete_all\", [payloadKeys]);\n const snakeOptions = camelToSnakeKeys(this._prepareParams(options));\n // @ts-ignore\n const params = new URLSearchParams(snakeOptions);\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/memories/?${params}`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n return response;\n }\n\n async history(memoryId: string): Promise<Array<MemoryHistory>> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"history\", []);\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/history/`,\n {\n headers: this.headers,\n },\n );\n return response;\n }\n\n async users(options?: {\n page?: number;\n pageSize?: number;\n }): Promise<AllUsers> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"users\", []);\n let url = `${this.host}/v1/entities/`;\n const params: string[] = [];\n if (options?.page) params.push(`page=${options.page}`);\n if (options?.pageSize) params.push(`page_size=${options.pageSize}`);\n if (params.length) url += `?${params.join(\"&\")}`;\n const response = await this._fetchWithErrorHandling(url, {\n headers: this.headers,\n });\n return response;\n }\n\n /**\n * @deprecated The method should not be used, use `deleteUsers` instead. This will be removed in version 2.2.0.\n */\n async deleteUser(data: {\n entity_id: number;\n entity_type: string;\n }): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"delete_user\", []);\n if (!data.entity_type) {\n data.entity_type = \"user\";\n }\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/entities/${data.entity_type}/${data.entity_id}/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n return response;\n }\n\n async deleteUsers(\n params: {\n userId?: string;\n agentId?: string;\n appId?: string;\n runId?: string;\n } = {},\n ): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n\n let to_delete: Array<{ type: string; name: string }> = [];\n const { userId, agentId, appId, runId } = params;\n\n if (userId) {\n to_delete = [{ type: \"user\", name: userId }];\n } else if (agentId) {\n to_delete = [{ type: \"agent\", name: agentId }];\n } else if (appId) {\n to_delete = [{ type: \"app\", name: appId }];\n } else if (runId) {\n to_delete = [{ type: \"run\", name: runId }];\n } else {\n const entities = await this.users();\n to_delete = entities.results.map((entity) => ({\n type: entity.type,\n name: entity.name,\n }));\n }\n\n if (to_delete.length === 0) {\n throw new Error(\"No entities to delete\");\n }\n\n for (const entity of to_delete) {\n try {\n await this.client.delete(`/v2/entities/${entity.type}/${entity.name}/`);\n } catch (error: any) {\n throw new APIError(\n `Failed to delete ${entity.type} ${entity.name}: ${error.message}`,\n );\n }\n }\n\n this._captureEvent(\"delete_users\", [\n { userId, agentId, appId, runId, sync_type: \"sync\" },\n ]);\n\n return {\n message:\n userId || agentId || appId || runId\n ? \"Entity deleted successfully.\"\n : \"All users, agents, apps and runs deleted.\",\n };\n }\n\n async batchUpdate(memories: Array<MemoryUpdateBody>): Promise<string> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"batch_update\", []);\n const memoriesBody = memories.map((memory) => ({\n memory_id: memory.memoryId,\n text: memory.text,\n }));\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/batch/`,\n {\n method: \"PUT\",\n headers: this.headers,\n body: JSON.stringify({ memories: memoriesBody }),\n },\n );\n return response;\n }\n\n async batchDelete(memories: Array<string>): Promise<string> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"batch_delete\", []);\n const memoriesBody = memories.map((memory) => ({\n memory_id: memory,\n }));\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/batch/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n body: JSON.stringify({ memories: memoriesBody }),\n },\n );\n return response;\n }\n\n async getProject(options: ProjectOptions): Promise<ProjectResponse> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"get_project\", [payloadKeys]);\n const { fields } = options;\n\n if (!(this.organizationId && this.projectId)) {\n throw new Error(\n \"organizationId and projectId must be set to access instructions or categories\",\n );\n }\n\n const params = new URLSearchParams();\n fields?.forEach((field) => params.append(\"fields\", camelToSnake(field)));\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/orgs/organizations/${this.organizationId}/projects/${this.projectId}/?${params.toString()}`,\n {\n headers: this.headers,\n },\n );\n return response;\n }\n\n async updateProject(\n prompts: PromptUpdatePayload,\n ): Promise<Record<string, any>> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"update_project\", []);\n if (!(this.organizationId && this.projectId)) {\n throw new Error(\n \"organizationId and projectId must be set to update instructions or categories\",\n );\n }\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/orgs/organizations/${this.organizationId}/projects/${this.projectId}/`,\n {\n method: \"PATCH\",\n headers: this.headers,\n body: JSON.stringify(camelToSnakeKeys(prompts)),\n },\n );\n return response;\n }\n\n // WebHooks\n async getWebhooks(data?: { projectId?: string }): Promise<Array<Webhook>> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"get_webhooks\", []);\n const project_id = data?.projectId || this.projectId;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/projects/${project_id}/`,\n {\n headers: this.headers,\n },\n );\n return response;\n }\n\n async createWebhook(webhook: WebhookCreatePayload): Promise<Webhook> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"create_webhook\", []);\n const body = {\n name: webhook.name,\n url: webhook.url,\n event_types: webhook.eventTypes,\n };\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/projects/${this.projectId}/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(body),\n },\n );\n return response;\n }\n\n async updateWebhook(\n webhook: WebhookUpdatePayload,\n ): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"update_webhook\", []);\n const body: Record<string, any> = {};\n if (webhook.name != null) body.name = webhook.name;\n if (webhook.url != null) body.url = webhook.url;\n if (webhook.eventTypes != null) body.event_types = webhook.eventTypes;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/${webhook.webhookId}/`,\n {\n method: \"PUT\",\n headers: this.headers,\n body: JSON.stringify(body),\n },\n );\n return response;\n }\n\n async deleteWebhook(data: {\n webhookId: string;\n }): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"delete_webhook\", []);\n const webhook_id = data.webhookId || data;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/${webhook_id}/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n return response;\n }\n\n async feedback(data: FeedbackPayload): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(data || {});\n this._captureEvent(\"feedback\", [payloadKeys]);\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/feedback/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(camelToSnakeKeys(data)),\n },\n );\n return response;\n }\n\n async createMemoryExport(\n data: CreateMemoryExportPayload,\n ): Promise<{ message: string; id: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"create_memory_export\", []);\n\n if (!data.filters || !data.schema) {\n throw new Error(\"Missing filters or schema\");\n }\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/exports/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(camelToSnakeKeys(data)),\n },\n );\n\n return response;\n }\n\n async getMemoryExport(\n data: GetMemoryExportPayload,\n ): Promise<{ message: string; id: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"get_memory_export\", []);\n\n if (!data.memoryExportId && !data.filters) {\n throw new Error(\"Missing memoryExportId or filters\");\n }\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/exports/get/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(camelToSnakeKeys(data)),\n },\n );\n return response;\n }\n}\n\nexport { MemoryClient };\n","// @ts-nocheck\nimport type { TelemetryClient, TelemetryOptions } from \"./telemetry.types\";\n\nlet version = \"2.1.36\";\n\n// Safely check for process.env in different environments\nlet MEM0_TELEMETRY = true;\ntry {\n MEM0_TELEMETRY = process?.env?.MEM0_TELEMETRY === \"false\" ? false : true;\n} catch (error) {}\nconst POSTHOG_API_KEY = \"phc_hgJkUVJFYtmaJqrvf6CYN67TIQ8yhXAkWzUn9AMU4yX\";\nconst POSTHOG_HOST = \"https://us.i.posthog.com/i/v0/e/\";\n\n// Simple hash function using random strings\nfunction generateHash(input: string): string {\n const randomStr =\n Math.random().toString(36).substring(2, 15) +\n Math.random().toString(36).substring(2, 15);\n return randomStr;\n}\n\nclass UnifiedTelemetry implements TelemetryClient {\n private apiKey: string;\n private host: string;\n\n constructor(projectApiKey: string, host: string) {\n this.apiKey = projectApiKey;\n this.host = host;\n }\n\n async captureEvent(distinctId: string, eventName: string, properties = {}) {\n if (!MEM0_TELEMETRY) return;\n\n const eventProperties = {\n client_version: version,\n timestamp: new Date().toISOString(),\n ...properties,\n $process_person_profile: false,\n $lib: \"posthog-node\",\n };\n\n const payload = {\n api_key: this.apiKey,\n distinct_id: distinctId,\n event: eventName,\n properties: eventProperties,\n };\n\n try {\n const response = await fetch(this.host, {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify(payload),\n });\n\n if (!response.ok) {\n console.error(\"Telemetry event capture failed:\", await response.text());\n }\n } catch (error) {\n console.error(\"Telemetry event capture failed:\", error);\n }\n }\n\n async shutdown() {\n // No shutdown needed for direct API calls\n }\n}\n\nconst telemetry = new UnifiedTelemetry(POSTHOG_API_KEY, POSTHOG_HOST);\n\nasync function captureClientEvent(\n eventName: string,\n instance: any,\n additionalData = {},\n) {\n if (!instance.telemetryId) {\n console.warn(\"No telemetry ID found for instance\");\n return;\n }\n\n const eventData = {\n function: `${instance.constructor.name}`,\n method: eventName,\n api_host: instance.host,\n timestamp: new Date().toISOString(),\n client_version: version,\n keys: additionalData?.keys || [],\n ...additionalData,\n };\n\n await telemetry.captureEvent(\n instance.telemetryId,\n `client.${eventName}`,\n eventData,\n );\n}\n\nexport { telemetry, captureClientEvent, generateHash };\n","/**\n * Converts a camelCase string to snake_case.\n */\nexport function camelToSnake(str: string): string {\n // Skip all-uppercase keys (e.g. OR, AND, NOT — logical operators)\n if (str === str.toUpperCase()) return str;\n return str.replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n}\n\n/**\n * Converts a snake_case string to camelCase.\n */\nfunction snakeToCamel(str: string): string {\n return str.replace(/_([a-z])/g, (_, letter) => letter.toUpperCase());\n}\n\n/**\n * Recursively converts all keys of an object from camelCase to snake_case.\n * Used for converting user-facing camelCase params to API snake_case payloads.\n */\nexport function camelToSnakeKeys(obj: any): any {\n if (obj === null || obj === undefined || typeof obj !== \"object\") return obj;\n if (Array.isArray(obj)) return obj.map(camelToSnakeKeys);\n if (obj instanceof Date) return obj;\n\n return Object.fromEntries(\n Object.entries(obj).map(([key, value]) => [\n camelToSnake(key),\n camelToSnakeKeys(value),\n ]),\n );\n}\n\n/**\n * Recursively converts all keys of an object from snake_case to camelCase.\n * Used for converting API snake_case responses to user-facing camelCase.\n */\nexport function snakeToCamelKeys(obj: any): any {\n if (obj === null || obj === undefined || typeof obj !== \"object\") return obj;\n if (Array.isArray(obj)) return obj.map(snakeToCamelKeys);\n if (obj instanceof Date) return obj;\n\n return Object.fromEntries(\n Object.entries(obj).map(([key, value]) => [\n snakeToCamel(key),\n snakeToCamelKeys(value),\n ]),\n );\n}\n","/**\n * Structured exception classes for mem0 TypeScript SDK.\n *\n * Provides specific, actionable exceptions with error codes, suggestions,\n * and debug information. Maps HTTP status codes to appropriate exception types.\n *\n * @example\n * ```typescript\n * import { RateLimitError, MemoryNotFoundError } from 'mem0ai'\n *\n * try {\n * await client.get(memoryId)\n * } catch (e) {\n * if (e instanceof MemoryNotFoundError) {\n * console.log(e.suggestion) // \"The requested resource was not found\"\n * } else if (e instanceof RateLimitError) {\n * await sleep(e.debugInfo.retryAfter ?? 60)\n * }\n * }\n * ```\n */\n\nexport interface MemoryErrorOptions {\n details?: Record<string, unknown>;\n suggestion?: string;\n debugInfo?: Record<string, unknown>;\n}\n\n/**\n * Base exception for all memory-related errors.\n *\n * Every mem0 exception includes an error code for programmatic handling,\n * optional details, a user-friendly suggestion, and debug information.\n */\nexport class MemoryError extends Error {\n readonly errorCode: string;\n readonly details: Record<string, unknown>;\n readonly suggestion?: string;\n readonly debugInfo: Record<string, unknown>;\n\n constructor(\n message: string,\n errorCode: string,\n options: MemoryErrorOptions = {},\n ) {\n super(message);\n this.name = \"MemoryError\";\n this.errorCode = errorCode;\n this.details = options.details ?? {};\n this.suggestion = options.suggestion;\n this.debugInfo = options.debugInfo ?? {};\n\n // Fix prototype chain for instanceof checks\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\n/** Raised when authentication fails (401, 403). */\nexport class AuthenticationError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"AuthenticationError\";\n }\n}\n\n/** Raised when rate limits are exceeded (429). */\nexport class RateLimitError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"RateLimitError\";\n }\n}\n\n/** Raised when input validation fails (400, 409, 422). */\nexport class ValidationError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"ValidationError\";\n }\n}\n\n/** Raised when a memory is not found (404). */\nexport class MemoryNotFoundError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"MemoryNotFoundError\";\n }\n}\n\n/** Raised when network connectivity issues occur (408, 502, 503, 504). */\nexport class NetworkError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"NetworkError\";\n }\n}\n\n/** Raised when client configuration is invalid. */\nexport class ConfigurationError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"ConfigurationError\";\n }\n}\n\n/** Raised when memory quota is exceeded (413). */\nexport class MemoryQuotaExceededError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"MemoryQuotaExceededError\";\n }\n}\n\n// ─── HTTP Status → Exception Mapping ─────────────────────\n\ntype MemoryErrorConstructor = new (\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n) => MemoryError;\n\nexport const HTTP_STATUS_TO_EXCEPTION: Record<number, MemoryErrorConstructor> =\n {\n 400: ValidationError,\n 401: AuthenticationError,\n 403: AuthenticationError,\n 404: MemoryNotFoundError,\n 408: NetworkError,\n 409: ValidationError,\n 413: MemoryQuotaExceededError,\n 422: ValidationError,\n 429: RateLimitError,\n 500: MemoryError,\n 502: NetworkError,\n 503: NetworkError,\n 504: NetworkError,\n };\n\nconst HTTP_SUGGESTIONS: Record<number, string> = {\n 400: \"Please check your request parameters and try again\",\n 401: \"Please check your API key and authentication credentials\",\n 403: \"You don't have permission to perform this operation\",\n 404: \"The requested resource was not found\",\n 408: \"Request timed out. Please try again\",\n 409: \"Resource conflict. Please check your request\",\n 413: \"Request too large. Please reduce the size of your request\",\n 422: \"Invalid request data. Please check your input\",\n 429: \"Rate limit exceeded. Please wait before making more requests\",\n 500: \"Internal server error. Please try again later\",\n 502: \"Service temporarily unavailable. Please try again later\",\n 503: \"Service unavailable. Please try again later\",\n 504: \"Gateway timeout. Please try again later\",\n};\n\n/**\n * Create an appropriate exception based on HTTP response status code.\n *\n * @param statusCode - HTTP status code from the response\n * @param responseText - Response body text\n * @param options - Additional error context (details, debugInfo)\n * @returns An instance of the appropriate MemoryError subclass\n */\nexport function createExceptionFromResponse(\n statusCode: number,\n responseText: string,\n options: Omit<MemoryErrorOptions, \"suggestion\"> = {},\n): MemoryError {\n const ExceptionClass = HTTP_STATUS_TO_EXCEPTION[statusCode] ?? MemoryError;\n const errorCode = `HTTP_${statusCode}`;\n const suggestion = HTTP_SUGGESTIONS[statusCode] ?? \"Please try again later\";\n\n return new ExceptionClass(\n responseText || `HTTP ${statusCode} error`,\n errorCode,\n { ...options, suggestion },\n );\n}\n","// ─── Entity Options (for add/delete — top-level identity) ───\nexport interface EntityOptions {\n userId?: string;\n agentId?: string;\n appId?: string;\n runId?: string;\n}\n\n// ─── Per-Method Options ─────────────────────────────────────\nexport interface AddMemoryOptions extends EntityOptions {\n metadata?: Record<string, any>;\n infer?: boolean;\n customCategories?: custom_categories[];\n customInstructions?: string;\n timestamp?: number;\n structuredDataSchema?: Record<string, any>;\n}\n\nexport interface SearchMemoryOptions {\n filters?: Record<string, any>;\n metadata?: Record<string, any>;\n topK?: number;\n threshold?: number;\n rerank?: boolean;\n fields?: string[];\n categories?: string[];\n}\n\nexport interface GetAllMemoryOptions {\n filters?: Record<string, any>;\n page?: number;\n pageSize?: number;\n startDate?: string;\n endDate?: string;\n categories?: string[];\n}\n\nexport interface DeleteAllMemoryOptions extends EntityOptions {}\n\n// ─── Project Options ────────────────────────────────────────\nexport interface ProjectOptions {\n fields?: string[];\n}\n\nexport interface PromptUpdatePayload {\n customInstructions?: string;\n customCategories?: custom_categories[];\n retrievalCriteria?: any[];\n version?: string;\n memoryDepth?: string | null;\n usecaseSetting?: string | number;\n multilingual?: boolean;\n [key: string]: any;\n}\n\n// ─── Enums ──────────────────────────────────────────────────\nexport enum Feedback {\n POSITIVE = \"POSITIVE\",\n NEGATIVE = \"NEGATIVE\",\n VERY_NEGATIVE = \"VERY_NEGATIVE\",\n}\n\n// ─── Message Types ──────────────────────────────────────────\nexport interface MultiModalMessages {\n type: \"image_url\";\n image_url: {\n url: string;\n };\n}\n\nexport interface Messages {\n role: \"user\" | \"assistant\";\n content: string | MultiModalMessages;\n}\n\nexport interface Message extends Messages {}\n\n// ─── Response Types (camelCase — converted from API snake_case) ─────\nexport interface MemoryData {\n memory: string;\n}\n\nenum Event {\n ADD = \"ADD\",\n UPDATE = \"UPDATE\",\n DELETE = \"DELETE\",\n NOOP = \"NOOP\",\n}\n\nexport interface Memory {\n id: string;\n messages?: Array<Messages>;\n event?: Event | string;\n data?: MemoryData | null;\n memory?: string;\n userId?: string;\n hash?: string;\n categories?: Array<string>;\n createdAt?: Date;\n updatedAt?: Date;\n memoryType?: string;\n score?: number;\n metadata?: any | null;\n owner?: string | null;\n agentId?: string | null;\n appId?: string | null;\n runId?: string | null;\n}\n\nexport interface MemoryHistory {\n id: string;\n memoryId: string;\n input: Array<Messages>;\n oldMemory: string | null;\n newMemory: string | null;\n userId: string;\n categories: Array<string>;\n event: Event | string;\n createdAt: Date;\n updatedAt: Date;\n}\n\nexport interface MemoryUpdateBody {\n memoryId: string;\n text: string;\n}\n\nexport interface User {\n id: string;\n name: string;\n createdAt: Date;\n updatedAt: Date;\n totalMemories: number;\n owner: string;\n type: string;\n}\n\nexport interface AllUsers {\n count: number;\n results: Array<User>;\n next: any;\n previous: any;\n}\n\nexport interface ProjectResponse {\n customInstructions?: string;\n customCategories?: string[];\n [key: string]: any;\n}\n\ninterface custom_categories {\n [key: string]: any;\n}\n\n// ─── Webhook Types ──────────────────────────────────────────\nexport enum WebhookEvent {\n MEMORY_ADDED = \"memory_add\",\n MEMORY_UPDATED = \"memory_update\",\n MEMORY_DELETED = \"memory_delete\",\n MEMORY_CATEGORIZED = \"memory_categorize\",\n}\n\nexport interface Webhook {\n webhookId?: string;\n name: string;\n url: string;\n project?: string;\n createdAt?: Date;\n updatedAt?: Date;\n isActive?: boolean;\n eventTypes?: WebhookEvent[];\n}\n\nexport interface WebhookCreatePayload {\n name: string;\n url: string;\n eventTypes: WebhookEvent[];\n}\n\nexport interface WebhookUpdatePayload {\n webhookId: string;\n name?: string;\n url?: string;\n eventTypes?: WebhookEvent[];\n}\n\n// ─── Feedback & Export Types ────────────────────────────────\nexport interface FeedbackPayload {\n memoryId: string;\n feedback?: Feedback | null;\n feedbackReason?: string | null;\n}\n\nexport interface CreateMemoryExportPayload {\n schema: Record<string, any>;\n filters: Record<string, any>;\n exportInstructions?: string;\n}\n\nexport interface GetMemoryExportPayload {\n filters?: Record<string, any>;\n memoryExportId?: string;\n}\n"],"mappings":"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","names":["_a","axios","_a","Feedback","WebhookEvent"]}
|
|
1
|
+
{"version":3,"sources":["../src/client/index.ts","../src/client/mem0.ts","../src/client/telemetry.ts","../src/client/utils.ts","../src/common/exceptions.ts","../src/client/mem0.types.ts"],"sourcesContent":["import { MemoryClient } from \"./mem0\";\nimport type * as MemoryTypes from \"./mem0.types\";\n\n// Re-export all types from mem0.types\nexport type {\n AddMemoryOptions,\n SearchMemoryOptions,\n GetAllMemoryOptions,\n DeleteAllMemoryOptions,\n ProjectOptions,\n Memory,\n MemoryHistory,\n MemoryUpdateBody,\n ProjectResponse,\n PromptUpdatePayload,\n Webhook,\n WebhookCreatePayload,\n WebhookUpdatePayload,\n Messages,\n Message,\n AllUsers,\n User,\n FeedbackPayload,\n CreateMemoryExportPayload,\n GetMemoryExportPayload,\n} from \"./mem0.types\";\n\n// Re-export enums as values (not type-only)\nexport { Feedback, WebhookEvent } from \"./mem0.types\";\n\n// Export the main client\nexport { MemoryClient };\nexport default MemoryClient;\n\n// Export structured exceptions\nexport {\n MemoryError,\n AuthenticationError,\n RateLimitError,\n ValidationError,\n MemoryNotFoundError,\n NetworkError,\n ConfigurationError,\n MemoryQuotaExceededError,\n createExceptionFromResponse,\n} from \"../common/exceptions\";\n\nexport type { MemoryErrorOptions } from \"../common/exceptions\";\n","import axios from \"axios\";\nimport {\n AllUsers,\n PaginatedMemories,\n ProjectOptions,\n Memory,\n MemoryHistory,\n AddMemoryOptions,\n SearchMemoryOptions,\n GetAllMemoryOptions,\n DeleteAllMemoryOptions,\n MemoryUpdateBody,\n ProjectResponse,\n PromptUpdatePayload,\n Webhook,\n WebhookCreatePayload,\n WebhookUpdatePayload,\n Message,\n FeedbackPayload,\n CreateMemoryExportPayload,\n GetMemoryExportPayload,\n} from \"./mem0.types\";\nimport { captureClientEvent, generateHash } from \"./telemetry\";\nimport { camelToSnake, camelToSnakeKeys, snakeToCamelKeys } from \"./utils\";\nimport { createExceptionFromResponse, MemoryError } from \"../common/exceptions\";\n\n// Entity params that must be passed via filters - check both snake_case and camelCase\nconst ENTITY_PARAMS = [\n \"user_id\",\n \"agent_id\",\n \"app_id\",\n \"run_id\",\n \"userId\",\n \"agentId\",\n \"appId\",\n \"runId\",\n];\n\n/**\n * Validates that no top-level entity parameters are passed.\n * @throws Error if entity params are found at top level\n */\nfunction rejectTopLevelEntityParams(\n options: Record<string, any> | undefined,\n methodName: string,\n): void {\n const invalidKeys = Object.keys(options ?? {}).filter((k) =>\n ENTITY_PARAMS.includes(k),\n );\n if (invalidKeys.length > 0) {\n throw new Error(\n `Top-level entity parameters [${invalidKeys.join(\", \")}] are not supported in ${methodName}(). ` +\n `Use filters: { user_id: \"...\" } instead.`,\n );\n }\n}\n\nclass APIError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"APIError\";\n }\n}\n\ninterface ClientOptions {\n apiKey: string;\n host?: string;\n}\n\nexport default class MemoryClient {\n apiKey: string;\n host: string;\n private organizationId: string | number | null;\n private projectId: string | number | null;\n headers: Record<string, string>;\n client: any;\n telemetryId: string;\n\n _validateApiKey(): any {\n if (!this.apiKey) {\n throw new Error(\"Mem0 API key is required\");\n }\n if (typeof this.apiKey !== \"string\") {\n throw new Error(\"Mem0 API key must be a string\");\n }\n if (this.apiKey.trim() === \"\") {\n throw new Error(\"Mem0 API key cannot be empty\");\n }\n }\n\n constructor(options: ClientOptions) {\n this.apiKey = options.apiKey;\n this.host = options.host || \"https://api.mem0.ai\";\n this.organizationId = null;\n this.projectId = null;\n\n this.headers = {\n Authorization: `Token ${this.apiKey}`,\n \"Content-Type\": \"application/json\",\n };\n\n this.client = axios.create({\n baseURL: this.host,\n headers: { Authorization: `Token ${this.apiKey}` },\n timeout: 60000,\n });\n\n this._validateApiKey();\n this.telemetryId = \"\";\n this._initializeClient();\n }\n\n private async _initializeClient() {\n try {\n await this.ping();\n\n if (!this.telemetryId) {\n this.telemetryId = generateHash(this.apiKey);\n }\n\n captureClientEvent(\"init\", this, {\n client_type: \"MemoryClient\",\n }).catch((error: any) => {\n console.error(\"Failed to capture event:\", error);\n });\n } catch (error: any) {\n console.error(\"Failed to initialize client:\", error);\n await captureClientEvent(\"init_error\", this, {\n error: error?.message || \"Unknown error\",\n stack: error?.stack || \"No stack trace\",\n });\n }\n }\n\n private _captureEvent(methodName: string, args: any[]) {\n captureClientEvent(methodName, this, {\n success: true,\n args_count: args.length,\n keys: args.length > 0 ? args[0] : [],\n }).catch((error: any) => {\n console.error(\"Failed to capture event:\", error);\n });\n }\n\n async _fetchWithErrorHandling(url: string, options: any): Promise<any> {\n const response = await fetch(url, {\n ...options,\n headers: {\n ...options.headers,\n Authorization: `Token ${this.apiKey}`,\n \"Mem0-User-ID\": this.telemetryId,\n },\n });\n if (!response.ok) {\n const errorData = await response.text();\n throw createExceptionFromResponse(response.status, errorData);\n }\n const jsonResponse = await response.json();\n return snakeToCamelKeys(jsonResponse);\n }\n\n _preparePayload(\n messages: Array<Message>,\n options: Record<string, any>,\n ): object {\n const payload: any = {};\n payload.messages = messages;\n return camelToSnakeKeys({ ...payload, ...options });\n }\n\n _prepareParams(options: Record<string, any>): object {\n return Object.fromEntries(\n Object.entries(options).filter(([_, v]) => v != null),\n );\n }\n\n async ping(): Promise<void> {\n try {\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/ping/`,\n {\n method: \"GET\",\n headers: {\n Authorization: `Token ${this.apiKey}`,\n },\n },\n );\n\n if (!response || typeof response !== \"object\") {\n throw new APIError(\"Invalid response format from ping endpoint\");\n }\n\n if (response.status !== \"ok\") {\n throw new APIError(response.message || \"API Key is invalid\");\n }\n\n const { orgId, projectId, userEmail } = response;\n\n if (orgId) this.organizationId = orgId;\n if (projectId) this.projectId = projectId;\n if (userEmail) this.telemetryId = userEmail;\n } catch (error: any) {\n // Pass through structured exceptions and APIError\n if (error instanceof MemoryError || error instanceof APIError) {\n throw error;\n } else {\n throw new APIError(\n `Failed to ping server: ${error.message || \"Unknown error\"}`,\n );\n }\n }\n }\n\n async add(\n messages: Array<Message>,\n options: AddMemoryOptions & Record<string, any> = {},\n ): Promise<Array<Memory>> {\n if (this.telemetryId === \"\") await this.ping();\n\n const payload = this._preparePayload(messages, options);\n const payloadKeys = Object.keys(payload);\n this._captureEvent(\"add\", [payloadKeys]);\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v3/memories/add/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(payload),\n },\n );\n return response;\n }\n\n async update(\n memoryId: string,\n {\n text,\n metadata,\n timestamp,\n }: {\n text?: string;\n metadata?: Record<string, any>;\n timestamp?: number | string;\n },\n ): Promise<Array<Memory>> {\n if (\n text === undefined &&\n metadata === undefined &&\n timestamp === undefined\n ) {\n throw new Error(\n \"At least one of text, metadata, or timestamp must be provided for update.\",\n );\n }\n\n if (this.telemetryId === \"\") await this.ping();\n const payload: Record<string, any> = {};\n if (text !== undefined) payload.text = text;\n if (metadata !== undefined) payload.metadata = metadata;\n if (timestamp !== undefined) payload.timestamp = timestamp;\n\n const payloadKeys = Object.keys(payload);\n this._captureEvent(\"update\", [payloadKeys]);\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/`,\n {\n method: \"PUT\",\n headers: this.headers,\n body: JSON.stringify(payload),\n },\n );\n return response;\n }\n\n async get(memoryId: string): Promise<Memory> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"get\", []);\n return this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/`,\n {\n headers: this.headers,\n },\n );\n }\n\n async getAll(options?: GetAllMemoryOptions): Promise<PaginatedMemories> {\n // Reject top-level entity params - must use filters instead\n rejectTopLevelEntityParams(options as Record<string, any>, \"getAll\");\n\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"get_all\", [payloadKeys]);\n const { page, pageSize, filters, ...rest } = options ?? {};\n const body: Record<string, any> = {\n ...camelToSnakeKeys(rest),\n ...(filters && { filters }),\n };\n\n let url = `${this.host}/v3/memories/`;\n if (page && pageSize) {\n url += `?page=${page}&page_size=${pageSize}`;\n }\n\n const response = await this._fetchWithErrorHandling(url, {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(body),\n });\n return response;\n }\n\n async search(\n query: string,\n options?: SearchMemoryOptions,\n ): Promise<{ results: Array<Memory> }> {\n // Reject top-level entity params - must use filters instead\n rejectTopLevelEntityParams(options as Record<string, any>, \"search\");\n\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"search\", [payloadKeys]);\n const { filters, ...rest } = options ?? {};\n const payload: Record<string, any> = {\n query,\n output_format: \"v1.1\",\n ...camelToSnakeKeys(rest),\n ...(filters && { filters }),\n };\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v3/memories/search/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(payload),\n },\n );\n return response;\n }\n\n async delete(memoryId: string): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"delete\", []);\n return this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n }\n\n async deleteAll(\n options: DeleteAllMemoryOptions = {},\n ): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"delete_all\", [payloadKeys]);\n const snakeOptions = camelToSnakeKeys(this._prepareParams(options));\n // @ts-ignore\n const params = new URLSearchParams(snakeOptions);\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/memories/?${params}`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n return response;\n }\n\n async history(memoryId: string): Promise<Array<MemoryHistory>> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"history\", []);\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/memories/${memoryId}/history/`,\n {\n headers: this.headers,\n },\n );\n return response;\n }\n\n async users(options?: {\n page?: number;\n pageSize?: number;\n }): Promise<AllUsers> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"users\", []);\n let url = `${this.host}/v1/entities/`;\n const params: string[] = [];\n if (options?.page) params.push(`page=${options.page}`);\n if (options?.pageSize) params.push(`page_size=${options.pageSize}`);\n if (params.length) url += `?${params.join(\"&\")}`;\n const response = await this._fetchWithErrorHandling(url, {\n headers: this.headers,\n });\n return response;\n }\n\n /**\n * @deprecated The method should not be used, use `deleteUsers` instead. This will be removed in version 2.2.0.\n */\n async deleteUser(data: {\n entity_id: number;\n entity_type: string;\n }): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"delete_user\", []);\n if (!data.entity_type) {\n data.entity_type = \"user\";\n }\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/entities/${data.entity_type}/${data.entity_id}/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n return response;\n }\n\n async deleteUsers(\n params: {\n userId?: string;\n agentId?: string;\n appId?: string;\n runId?: string;\n } = {},\n ): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n\n let to_delete: Array<{ type: string; name: string }> = [];\n const { userId, agentId, appId, runId } = params;\n\n if (userId) {\n to_delete = [{ type: \"user\", name: userId }];\n } else if (agentId) {\n to_delete = [{ type: \"agent\", name: agentId }];\n } else if (appId) {\n to_delete = [{ type: \"app\", name: appId }];\n } else if (runId) {\n to_delete = [{ type: \"run\", name: runId }];\n } else {\n const entities = await this.users();\n to_delete = entities.results.map((entity) => ({\n type: entity.type,\n name: entity.name,\n }));\n }\n\n if (to_delete.length === 0) {\n throw new Error(\"No entities to delete\");\n }\n\n for (const entity of to_delete) {\n try {\n await this.client.delete(`/v2/entities/${entity.type}/${entity.name}/`);\n } catch (error: any) {\n throw new APIError(\n `Failed to delete ${entity.type} ${entity.name}: ${error.message}`,\n );\n }\n }\n\n this._captureEvent(\"delete_users\", [\n { userId, agentId, appId, runId, sync_type: \"sync\" },\n ]);\n\n return {\n message:\n userId || agentId || appId || runId\n ? \"Entity deleted successfully.\"\n : \"All users, agents, apps and runs deleted.\",\n };\n }\n\n async batchUpdate(memories: Array<MemoryUpdateBody>): Promise<string> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"batch_update\", []);\n const memoriesBody = memories.map((memory) => ({\n memory_id: memory.memoryId,\n text: memory.text,\n }));\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/batch/`,\n {\n method: \"PUT\",\n headers: this.headers,\n body: JSON.stringify({ memories: memoriesBody }),\n },\n );\n return response;\n }\n\n async batchDelete(memories: Array<string>): Promise<string> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"batch_delete\", []);\n const memoriesBody = memories.map((memory) => ({\n memory_id: memory,\n }));\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/batch/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n body: JSON.stringify({ memories: memoriesBody }),\n },\n );\n return response;\n }\n\n async getProject(options: ProjectOptions): Promise<ProjectResponse> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(options || {});\n this._captureEvent(\"get_project\", [payloadKeys]);\n const { fields } = options;\n\n if (!(this.organizationId && this.projectId)) {\n throw new Error(\n \"organizationId and projectId must be set to access instructions or categories\",\n );\n }\n\n const params = new URLSearchParams();\n fields?.forEach((field) => params.append(\"fields\", camelToSnake(field)));\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/orgs/organizations/${this.organizationId}/projects/${this.projectId}/?${params.toString()}`,\n {\n headers: this.headers,\n },\n );\n return response;\n }\n\n async updateProject(\n prompts: PromptUpdatePayload,\n ): Promise<Record<string, any>> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"update_project\", []);\n if (!(this.organizationId && this.projectId)) {\n throw new Error(\n \"organizationId and projectId must be set to update instructions or categories\",\n );\n }\n\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/orgs/organizations/${this.organizationId}/projects/${this.projectId}/`,\n {\n method: \"PATCH\",\n headers: this.headers,\n body: JSON.stringify(camelToSnakeKeys(prompts)),\n },\n );\n return response;\n }\n\n // WebHooks\n async getWebhooks(data?: { projectId?: string }): Promise<Array<Webhook>> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"get_webhooks\", []);\n const project_id = data?.projectId || this.projectId;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/projects/${project_id}/`,\n {\n headers: this.headers,\n },\n );\n return response;\n }\n\n async createWebhook(webhook: WebhookCreatePayload): Promise<Webhook> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"create_webhook\", []);\n const body = {\n name: webhook.name,\n url: webhook.url,\n event_types: webhook.eventTypes,\n };\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/projects/${this.projectId}/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(body),\n },\n );\n return response;\n }\n\n async updateWebhook(\n webhook: WebhookUpdatePayload,\n ): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"update_webhook\", []);\n const body: Record<string, any> = {};\n if (webhook.name != null) body.name = webhook.name;\n if (webhook.url != null) body.url = webhook.url;\n if (webhook.eventTypes != null) body.event_types = webhook.eventTypes;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/${webhook.webhookId}/`,\n {\n method: \"PUT\",\n headers: this.headers,\n body: JSON.stringify(body),\n },\n );\n return response;\n }\n\n async deleteWebhook(data: {\n webhookId: string;\n }): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"delete_webhook\", []);\n const webhook_id = data.webhookId || data;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/api/v1/webhooks/${webhook_id}/`,\n {\n method: \"DELETE\",\n headers: this.headers,\n },\n );\n return response;\n }\n\n async feedback(data: FeedbackPayload): Promise<{ message: string }> {\n if (this.telemetryId === \"\") await this.ping();\n const payloadKeys = Object.keys(data || {});\n this._captureEvent(\"feedback\", [payloadKeys]);\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/feedback/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify(camelToSnakeKeys(data)),\n },\n );\n return response;\n }\n\n async createMemoryExport(\n data: CreateMemoryExportPayload,\n ): Promise<{ message: string; id: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"create_memory_export\", []);\n\n if (!data.filters || !data.schema) {\n throw new Error(\"Missing filters or schema\");\n }\n\n const { filters, ...rest } = data;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/exports/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify({\n ...camelToSnakeKeys(rest),\n filters,\n }),\n },\n );\n\n return response;\n }\n\n async getMemoryExport(\n data: GetMemoryExportPayload,\n ): Promise<{ message: string; id: string }> {\n if (this.telemetryId === \"\") await this.ping();\n this._captureEvent(\"get_memory_export\", []);\n\n if (!data.memoryExportId && !data.filters) {\n throw new Error(\"Missing memoryExportId or filters\");\n }\n\n const { filters, ...rest } = data;\n const response = await this._fetchWithErrorHandling(\n `${this.host}/v1/exports/get/`,\n {\n method: \"POST\",\n headers: this.headers,\n body: JSON.stringify({\n ...camelToSnakeKeys(rest),\n ...(filters && { filters }),\n }),\n },\n );\n return response;\n }\n}\n\nexport { MemoryClient };\n","// @ts-nocheck\nimport type { TelemetryClient, TelemetryOptions } from \"./telemetry.types\";\n\nlet version = \"2.1.36\";\n\n// Safely check for process.env in different environments\nlet MEM0_TELEMETRY = true;\ntry {\n MEM0_TELEMETRY = process?.env?.MEM0_TELEMETRY === \"false\" ? false : true;\n} catch (error) {}\nconst POSTHOG_API_KEY = \"phc_hgJkUVJFYtmaJqrvf6CYN67TIQ8yhXAkWzUn9AMU4yX\";\nconst POSTHOG_HOST = \"https://us.i.posthog.com/i/v0/e/\";\n\n// Simple hash function using random strings\nfunction generateHash(input: string): string {\n const randomStr =\n Math.random().toString(36).substring(2, 15) +\n Math.random().toString(36).substring(2, 15);\n return randomStr;\n}\n\nclass UnifiedTelemetry implements TelemetryClient {\n private apiKey: string;\n private host: string;\n\n constructor(projectApiKey: string, host: string) {\n this.apiKey = projectApiKey;\n this.host = host;\n }\n\n async captureEvent(distinctId: string, eventName: string, properties = {}) {\n if (!MEM0_TELEMETRY) return;\n\n const eventProperties = {\n client_version: version,\n timestamp: new Date().toISOString(),\n ...properties,\n $process_person_profile: false,\n $lib: \"posthog-node\",\n };\n\n const payload = {\n api_key: this.apiKey,\n distinct_id: distinctId,\n event: eventName,\n properties: eventProperties,\n };\n\n try {\n const response = await fetch(this.host, {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify(payload),\n });\n\n if (!response.ok) {\n console.error(\"Telemetry event capture failed:\", await response.text());\n }\n } catch (error) {\n console.error(\"Telemetry event capture failed:\", error);\n }\n }\n\n async shutdown() {\n // No shutdown needed for direct API calls\n }\n}\n\nconst telemetry = new UnifiedTelemetry(POSTHOG_API_KEY, POSTHOG_HOST);\n\nasync function captureClientEvent(\n eventName: string,\n instance: any,\n additionalData = {},\n) {\n if (!instance.telemetryId) {\n console.warn(\"No telemetry ID found for instance\");\n return;\n }\n\n const eventData = {\n function: `${instance.constructor.name}`,\n method: eventName,\n api_host: instance.host,\n timestamp: new Date().toISOString(),\n client_version: version,\n keys: additionalData?.keys || [],\n ...additionalData,\n };\n\n await telemetry.captureEvent(\n instance.telemetryId,\n `client.${eventName}`,\n eventData,\n );\n}\n\nexport { telemetry, captureClientEvent, generateHash };\n","/**\n * Converts a camelCase string to snake_case.\n */\nexport function camelToSnake(str: string): string {\n // Skip all-uppercase keys (e.g. OR, AND, NOT — logical operators)\n if (str === str.toUpperCase()) return str;\n return str.replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n}\n\n/**\n * Converts a snake_case string to camelCase.\n */\nfunction snakeToCamel(str: string): string {\n return str.replace(/_([a-z])/g, (_, letter) => letter.toUpperCase());\n}\n\n/**\n * Recursively converts all keys of an object from camelCase to snake_case.\n * Used for converting user-facing camelCase params to API snake_case payloads.\n */\nexport function camelToSnakeKeys(obj: any): any {\n if (obj === null || obj === undefined || typeof obj !== \"object\") return obj;\n if (Array.isArray(obj)) return obj.map(camelToSnakeKeys);\n if (obj instanceof Date) return obj;\n\n return Object.fromEntries(\n Object.entries(obj).map(([key, value]) => [\n camelToSnake(key),\n camelToSnakeKeys(value),\n ]),\n );\n}\n\n/**\n * Recursively converts all keys of an object from snake_case to camelCase.\n * Used for converting API snake_case responses to user-facing camelCase.\n */\nexport function snakeToCamelKeys(obj: any): any {\n if (obj === null || obj === undefined || typeof obj !== \"object\") return obj;\n if (Array.isArray(obj)) return obj.map(snakeToCamelKeys);\n if (obj instanceof Date) return obj;\n\n return Object.fromEntries(\n Object.entries(obj).map(([key, value]) => [\n snakeToCamel(key),\n snakeToCamelKeys(value),\n ]),\n );\n}\n","/**\n * Structured exception classes for mem0 TypeScript SDK.\n *\n * Provides specific, actionable exceptions with error codes, suggestions,\n * and debug information. Maps HTTP status codes to appropriate exception types.\n *\n * @example\n * ```typescript\n * import { RateLimitError, MemoryNotFoundError } from 'mem0ai'\n *\n * try {\n * await client.get(memoryId)\n * } catch (e) {\n * if (e instanceof MemoryNotFoundError) {\n * console.log(e.suggestion) // \"The requested resource was not found\"\n * } else if (e instanceof RateLimitError) {\n * await sleep(e.debugInfo.retryAfter ?? 60)\n * }\n * }\n * ```\n */\n\nexport interface MemoryErrorOptions {\n details?: Record<string, unknown>;\n suggestion?: string;\n debugInfo?: Record<string, unknown>;\n}\n\n/**\n * Base exception for all memory-related errors.\n *\n * Every mem0 exception includes an error code for programmatic handling,\n * optional details, a user-friendly suggestion, and debug information.\n */\nexport class MemoryError extends Error {\n readonly errorCode: string;\n readonly details: Record<string, unknown>;\n readonly suggestion?: string;\n readonly debugInfo: Record<string, unknown>;\n\n constructor(\n message: string,\n errorCode: string,\n options: MemoryErrorOptions = {},\n ) {\n super(message);\n this.name = \"MemoryError\";\n this.errorCode = errorCode;\n this.details = options.details ?? {};\n this.suggestion = options.suggestion;\n this.debugInfo = options.debugInfo ?? {};\n\n // Fix prototype chain for instanceof checks\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\n/** Raised when authentication fails (401, 403). */\nexport class AuthenticationError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"AuthenticationError\";\n }\n}\n\n/** Raised when rate limits are exceeded (429). */\nexport class RateLimitError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"RateLimitError\";\n }\n}\n\n/** Raised when input validation fails (400, 409, 422). */\nexport class ValidationError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"ValidationError\";\n }\n}\n\n/** Raised when a memory is not found (404). */\nexport class MemoryNotFoundError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"MemoryNotFoundError\";\n }\n}\n\n/** Raised when network connectivity issues occur (408, 502, 503, 504). */\nexport class NetworkError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"NetworkError\";\n }\n}\n\n/** Raised when client configuration is invalid. */\nexport class ConfigurationError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"ConfigurationError\";\n }\n}\n\n/** Raised when memory quota is exceeded (413). */\nexport class MemoryQuotaExceededError extends MemoryError {\n constructor(\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n ) {\n super(message, errorCode, options);\n this.name = \"MemoryQuotaExceededError\";\n }\n}\n\n// ─── HTTP Status → Exception Mapping ─────────────────────\n\ntype MemoryErrorConstructor = new (\n message: string,\n errorCode: string,\n options?: MemoryErrorOptions,\n) => MemoryError;\n\nexport const HTTP_STATUS_TO_EXCEPTION: Record<number, MemoryErrorConstructor> =\n {\n 400: ValidationError,\n 401: AuthenticationError,\n 403: AuthenticationError,\n 404: MemoryNotFoundError,\n 408: NetworkError,\n 409: ValidationError,\n 413: MemoryQuotaExceededError,\n 422: ValidationError,\n 429: RateLimitError,\n 500: MemoryError,\n 502: NetworkError,\n 503: NetworkError,\n 504: NetworkError,\n };\n\nconst HTTP_SUGGESTIONS: Record<number, string> = {\n 400: \"Please check your request parameters and try again\",\n 401: \"Please check your API key and authentication credentials\",\n 403: \"You don't have permission to perform this operation\",\n 404: \"The requested resource was not found\",\n 408: \"Request timed out. Please try again\",\n 409: \"Resource conflict. Please check your request\",\n 413: \"Request too large. Please reduce the size of your request\",\n 422: \"Invalid request data. Please check your input\",\n 429: \"Rate limit exceeded. Please wait before making more requests\",\n 500: \"Internal server error. Please try again later\",\n 502: \"Service temporarily unavailable. Please try again later\",\n 503: \"Service unavailable. Please try again later\",\n 504: \"Gateway timeout. Please try again later\",\n};\n\n/**\n * Create an appropriate exception based on HTTP response status code.\n *\n * @param statusCode - HTTP status code from the response\n * @param responseText - Response body text\n * @param options - Additional error context (details, debugInfo)\n * @returns An instance of the appropriate MemoryError subclass\n */\nexport function createExceptionFromResponse(\n statusCode: number,\n responseText: string,\n options: Omit<MemoryErrorOptions, \"suggestion\"> = {},\n): MemoryError {\n const ExceptionClass = HTTP_STATUS_TO_EXCEPTION[statusCode] ?? MemoryError;\n const errorCode = `HTTP_${statusCode}`;\n const suggestion = HTTP_SUGGESTIONS[statusCode] ?? \"Please try again later\";\n\n return new ExceptionClass(\n responseText || `HTTP ${statusCode} error`,\n errorCode,\n { ...options, suggestion },\n );\n}\n","// ─── Entity Options (for add/delete — top-level identity) ───\nexport interface EntityOptions {\n userId?: string;\n agentId?: string;\n appId?: string;\n runId?: string;\n}\n\n// ─── Per-Method Options ─────────────────────────────────────\nexport interface AddMemoryOptions extends EntityOptions {\n metadata?: Record<string, any>;\n infer?: boolean;\n customCategories?: custom_categories[];\n customInstructions?: string;\n timestamp?: number;\n structuredDataSchema?: Record<string, any>;\n}\n\nexport interface SearchMemoryOptions {\n filters?: Record<string, any>;\n metadata?: Record<string, any>;\n topK?: number;\n threshold?: number;\n rerank?: boolean;\n fields?: string[];\n categories?: string[];\n}\n\nexport interface GetAllMemoryOptions {\n filters?: Record<string, any>;\n page?: number;\n pageSize?: number;\n startDate?: string;\n endDate?: string;\n categories?: string[];\n}\n\nexport interface DeleteAllMemoryOptions extends EntityOptions {}\n\n// ─── Project Options ────────────────────────────────────────\nexport interface ProjectOptions {\n fields?: string[];\n}\n\nexport interface PromptUpdatePayload {\n customInstructions?: string;\n customCategories?: custom_categories[];\n retrievalCriteria?: any[];\n version?: string;\n memoryDepth?: string | null;\n usecaseSetting?: string | number;\n multilingual?: boolean;\n [key: string]: any;\n}\n\n// ─── Enums ──────────────────────────────────────────────────\nexport enum Feedback {\n POSITIVE = \"POSITIVE\",\n NEGATIVE = \"NEGATIVE\",\n VERY_NEGATIVE = \"VERY_NEGATIVE\",\n}\n\n// ─── Message Types ──────────────────────────────────────────\nexport interface MultiModalMessages {\n type: \"image_url\";\n image_url: {\n url: string;\n };\n}\n\nexport interface Messages {\n role: \"user\" | \"assistant\";\n content: string | MultiModalMessages;\n}\n\nexport interface Message extends Messages {}\n\n// ─── Response Types (camelCase — converted from API snake_case) ─────\nexport interface MemoryData {\n memory: string;\n}\n\nenum Event {\n ADD = \"ADD\",\n UPDATE = \"UPDATE\",\n DELETE = \"DELETE\",\n NOOP = \"NOOP\",\n}\n\nexport interface Memory {\n id: string;\n messages?: Array<Messages>;\n event?: Event | string;\n data?: MemoryData | null;\n memory?: string;\n userId?: string;\n hash?: string;\n categories?: Array<string>;\n createdAt?: Date;\n updatedAt?: Date;\n memoryType?: string;\n score?: number;\n metadata?: any | null;\n owner?: string | null;\n agentId?: string | null;\n appId?: string | null;\n runId?: string | null;\n}\n\nexport interface MemoryHistory {\n id: string;\n memoryId: string;\n input: Array<Messages>;\n oldMemory: string | null;\n newMemory: string | null;\n userId: string;\n categories: Array<string>;\n event: Event | string;\n createdAt: Date;\n updatedAt: Date;\n}\n\nexport interface MemoryUpdateBody {\n memoryId: string;\n text: string;\n}\n\nexport interface User {\n id: string;\n name: string;\n createdAt: Date;\n updatedAt: Date;\n totalMemories: number;\n owner: string;\n type: string;\n}\n\nexport interface AllUsers {\n count: number;\n results: Array<User>;\n next: any;\n previous: any;\n}\n\nexport interface PaginatedMemories {\n count: number;\n next: string | null;\n previous: string | null;\n results: Array<Memory>;\n}\n\nexport interface ProjectResponse {\n customInstructions?: string;\n customCategories?: string[];\n [key: string]: any;\n}\n\ninterface custom_categories {\n [key: string]: any;\n}\n\n// ─── Webhook Types ──────────────────────────────────────────\nexport enum WebhookEvent {\n MEMORY_ADDED = \"memory_add\",\n MEMORY_UPDATED = \"memory_update\",\n MEMORY_DELETED = \"memory_delete\",\n MEMORY_CATEGORIZED = \"memory_categorize\",\n}\n\nexport interface Webhook {\n webhookId?: string;\n name: string;\n url: string;\n project?: string;\n createdAt?: Date;\n updatedAt?: Date;\n isActive?: boolean;\n eventTypes?: WebhookEvent[];\n}\n\nexport interface WebhookCreatePayload {\n name: string;\n url: string;\n eventTypes: WebhookEvent[];\n}\n\nexport interface WebhookUpdatePayload {\n webhookId: string;\n name?: string;\n url?: string;\n eventTypes?: WebhookEvent[];\n}\n\n// ─── Feedback & Export Types ────────────────────────────────\nexport interface FeedbackPayload {\n memoryId: string;\n feedback?: Feedback | null;\n feedbackReason?: string | null;\n}\n\nexport interface CreateMemoryExportPayload {\n schema: Record<string, any>;\n filters: Record<string, any>;\n exportInstructions?: string;\n}\n\nexport interface GetMemoryExportPayload {\n filters?: Record<string, any>;\n memoryExportId?: string;\n}\n"],"mappings":"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","names":["_a","axios","Feedback","WebhookEvent"]}
|
package/dist/index.mjs
CHANGED
|
@@ -204,6 +204,26 @@ function createExceptionFromResponse(statusCode, responseText, options = {}) {
|
|
|
204
204
|
}
|
|
205
205
|
|
|
206
206
|
// src/client/mem0.ts
|
|
207
|
+
var ENTITY_PARAMS = [
|
|
208
|
+
"user_id",
|
|
209
|
+
"agent_id",
|
|
210
|
+
"app_id",
|
|
211
|
+
"run_id",
|
|
212
|
+
"userId",
|
|
213
|
+
"agentId",
|
|
214
|
+
"appId",
|
|
215
|
+
"runId"
|
|
216
|
+
];
|
|
217
|
+
function rejectTopLevelEntityParams(options, methodName) {
|
|
218
|
+
const invalidKeys = Object.keys(options != null ? options : {}).filter(
|
|
219
|
+
(k) => ENTITY_PARAMS.includes(k)
|
|
220
|
+
);
|
|
221
|
+
if (invalidKeys.length > 0) {
|
|
222
|
+
throw new Error(
|
|
223
|
+
`Top-level entity parameters [${invalidKeys.join(", ")}] are not supported in ${methodName}(). Use filters: { user_id: "..." } instead.`
|
|
224
|
+
);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
207
227
|
var APIError = class extends Error {
|
|
208
228
|
constructor(message) {
|
|
209
229
|
super(message);
|
|
@@ -331,7 +351,7 @@ var MemoryClient = class {
|
|
|
331
351
|
const payloadKeys = Object.keys(payload);
|
|
332
352
|
this._captureEvent("add", [payloadKeys]);
|
|
333
353
|
const response = await this._fetchWithErrorHandling(
|
|
334
|
-
`${this.host}/
|
|
354
|
+
`${this.host}/v3/memories/add/`,
|
|
335
355
|
{
|
|
336
356
|
method: "POST",
|
|
337
357
|
headers: this.headers,
|
|
@@ -378,16 +398,16 @@ var MemoryClient = class {
|
|
|
378
398
|
);
|
|
379
399
|
}
|
|
380
400
|
async getAll(options) {
|
|
381
|
-
|
|
401
|
+
rejectTopLevelEntityParams(options, "getAll");
|
|
382
402
|
if (this.telemetryId === "") await this.ping();
|
|
383
403
|
const payloadKeys = Object.keys(options || {});
|
|
384
404
|
this._captureEvent("get_all", [payloadKeys]);
|
|
385
|
-
const { page, pageSize, ...rest } = options != null ? options : {};
|
|
405
|
+
const { page, pageSize, filters, ...rest } = options != null ? options : {};
|
|
386
406
|
const body = {
|
|
387
|
-
|
|
388
|
-
...
|
|
407
|
+
...camelToSnakeKeys(rest),
|
|
408
|
+
...filters && { filters }
|
|
389
409
|
};
|
|
390
|
-
let url = `${this.host}/
|
|
410
|
+
let url = `${this.host}/v3/memories/`;
|
|
391
411
|
if (page && pageSize) {
|
|
392
412
|
url += `?page=${page}&page_size=${pageSize}`;
|
|
393
413
|
}
|
|
@@ -396,27 +416,29 @@ var MemoryClient = class {
|
|
|
396
416
|
headers: this.headers,
|
|
397
417
|
body: JSON.stringify(body)
|
|
398
418
|
});
|
|
399
|
-
return
|
|
419
|
+
return response;
|
|
400
420
|
}
|
|
401
421
|
async search(query, options) {
|
|
402
|
-
|
|
422
|
+
rejectTopLevelEntityParams(options, "search");
|
|
403
423
|
if (this.telemetryId === "") await this.ping();
|
|
404
424
|
const payloadKeys = Object.keys(options || {});
|
|
405
425
|
this._captureEvent("search", [payloadKeys]);
|
|
426
|
+
const { filters, ...rest } = options != null ? options : {};
|
|
406
427
|
const payload = {
|
|
407
428
|
query,
|
|
408
429
|
output_format: "v1.1",
|
|
409
|
-
...camelToSnakeKeys(
|
|
430
|
+
...camelToSnakeKeys(rest),
|
|
431
|
+
...filters && { filters }
|
|
410
432
|
};
|
|
411
433
|
const response = await this._fetchWithErrorHandling(
|
|
412
|
-
`${this.host}/
|
|
434
|
+
`${this.host}/v3/memories/search/`,
|
|
413
435
|
{
|
|
414
436
|
method: "POST",
|
|
415
437
|
headers: this.headers,
|
|
416
438
|
body: JSON.stringify(payload)
|
|
417
439
|
}
|
|
418
440
|
);
|
|
419
|
-
return
|
|
441
|
+
return response;
|
|
420
442
|
}
|
|
421
443
|
async delete(memoryId) {
|
|
422
444
|
if (this.telemetryId === "") await this.ping();
|
|
@@ -676,12 +698,16 @@ var MemoryClient = class {
|
|
|
676
698
|
if (!data.filters || !data.schema) {
|
|
677
699
|
throw new Error("Missing filters or schema");
|
|
678
700
|
}
|
|
701
|
+
const { filters, ...rest } = data;
|
|
679
702
|
const response = await this._fetchWithErrorHandling(
|
|
680
703
|
`${this.host}/v1/exports/`,
|
|
681
704
|
{
|
|
682
705
|
method: "POST",
|
|
683
706
|
headers: this.headers,
|
|
684
|
-
body: JSON.stringify(
|
|
707
|
+
body: JSON.stringify({
|
|
708
|
+
...camelToSnakeKeys(rest),
|
|
709
|
+
filters
|
|
710
|
+
})
|
|
685
711
|
}
|
|
686
712
|
);
|
|
687
713
|
return response;
|
|
@@ -692,12 +718,16 @@ var MemoryClient = class {
|
|
|
692
718
|
if (!data.memoryExportId && !data.filters) {
|
|
693
719
|
throw new Error("Missing memoryExportId or filters");
|
|
694
720
|
}
|
|
721
|
+
const { filters, ...rest } = data;
|
|
695
722
|
const response = await this._fetchWithErrorHandling(
|
|
696
723
|
`${this.host}/v1/exports/get/`,
|
|
697
724
|
{
|
|
698
725
|
method: "POST",
|
|
699
726
|
headers: this.headers,
|
|
700
|
-
body: JSON.stringify(
|
|
727
|
+
body: JSON.stringify({
|
|
728
|
+
...camelToSnakeKeys(rest),
|
|
729
|
+
...filters && { filters }
|
|
730
|
+
})
|
|
701
731
|
}
|
|
702
732
|
);
|
|
703
733
|
return response;
|