@elizaos/plugin-memory 1.1.1 → 2.0.0-alpha

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 (44) hide show
  1. package/dist/evaluators/index.d.ts +3 -0
  2. package/dist/evaluators/index.d.ts.map +1 -0
  3. package/dist/evaluators/long-term-extraction.d.ts +1 -6
  4. package/dist/evaluators/long-term-extraction.d.ts.map +1 -0
  5. package/dist/evaluators/summarization.d.ts +1 -28
  6. package/dist/evaluators/summarization.d.ts.map +1 -0
  7. package/dist/generated/prompts/typescript/prompts.d.ts +16 -0
  8. package/dist/generated/prompts/typescript/prompts.d.ts.map +1 -0
  9. package/dist/index.d.ts +7 -39
  10. package/dist/index.d.ts.map +1 -0
  11. package/dist/{node/index.node.js → index.js} +800 -981
  12. package/dist/index.js.map +20 -0
  13. package/dist/providers/context-summary.d.ts +2 -11
  14. package/dist/providers/context-summary.d.ts.map +1 -0
  15. package/dist/providers/index.d.ts +3 -0
  16. package/dist/providers/index.d.ts.map +1 -0
  17. package/dist/providers/long-term-memory.d.ts +2 -16
  18. package/dist/providers/long-term-memory.d.ts.map +1 -0
  19. package/dist/schemas/index.d.ts +4 -9
  20. package/dist/schemas/index.d.ts.map +1 -0
  21. package/dist/schemas/long-term-memories.d.ts +1 -4
  22. package/dist/schemas/long-term-memories.d.ts.map +1 -0
  23. package/dist/schemas/memory-access-logs.d.ts +20 -58
  24. package/dist/schemas/memory-access-logs.d.ts.map +1 -0
  25. package/dist/schemas/session-summaries.d.ts +1 -4
  26. package/dist/schemas/session-summaries.d.ts.map +1 -0
  27. package/dist/services/memory-service.d.ts +7 -75
  28. package/dist/services/memory-service.d.ts.map +1 -0
  29. package/dist/types/index.d.ts +5 -26
  30. package/dist/types/index.d.ts.map +1 -0
  31. package/package.json +45 -48
  32. package/README.md +0 -335
  33. package/dist/actions/remember.d.ts +0 -11
  34. package/dist/browser/index.browser.js +0 -209
  35. package/dist/browser/index.browser.js.map +0 -20
  36. package/dist/browser/index.d.ts +0 -2
  37. package/dist/cjs/index.d.ts +0 -2
  38. package/dist/cjs/index.node.cjs +0 -1293
  39. package/dist/cjs/index.node.js.map +0 -20
  40. package/dist/index.browser.d.ts +0 -2
  41. package/dist/index.node.d.ts +0 -2
  42. package/dist/node/index.d.ts +0 -2
  43. package/dist/node/index.node.js.map +0 -20
  44. package/dist/providers/recent-messages.d.ts +0 -15
@@ -1,20 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/services/memory-service.ts", "../../src/schemas/long-term-memories.ts", "../../src/schemas/session-summaries.ts", "../../src/schemas/memory-access-logs.ts", "../../src/evaluators/summarization.ts", "../../src/evaluators/long-term-extraction.ts", "../../src/types/index.ts", "../../src/providers/long-term-memory.ts", "../../src/providers/context-summary.ts", "../../src/providers/recent-messages.ts", "../../src/index.ts"],
4
- "sourcesContent": [
5
- "import {\n type IAgentRuntime,\n Service,\n type UUID,\n logger,\n type ServiceTypeName,\n} from '@elizaos/core';\nimport { eq, and, desc, sql, cosineDistance, gte } from 'drizzle-orm';\nimport {\n type LongTermMemory,\n type SessionSummary,\n type MemoryConfig,\n LongTermMemoryCategory,\n} from '../types/index';\nimport { longTermMemories, sessionSummaries } from '../schemas/index';\n\n/**\n * Memory Service\n * Manages both short-term (session summaries) and long-term (persistent facts) memory\n */\nexport class MemoryService extends Service {\n static serviceType: ServiceTypeName = 'memory' as ServiceTypeName;\n\n private sessionMessageCounts: Map<UUID, number>;\n private memoryConfig: MemoryConfig;\n private lastExtractionCheckpoints: Map<string, number>; // Track last extraction per entity-room pair\n\n capabilityDescription =\n 'Advanced memory management with short-term summarization and long-term persistent facts';\n\n constructor(runtime?: IAgentRuntime) {\n super(runtime);\n this.sessionMessageCounts = new Map();\n this.lastExtractionCheckpoints = new Map();\n this.memoryConfig = {\n shortTermSummarizationThreshold: 16, // Start summarization at 16 messages\n shortTermRetainRecent: 6, // Show last 6 messages when summarization is active\n shortTermSummarizationInterval: 10, // Update summary every 10 new messages\n longTermExtractionEnabled: true,\n longTermVectorSearchEnabled: false,\n longTermConfidenceThreshold: 0.85, // Stricter threshold - only high-confidence extractions\n longTermExtractionThreshold: 30, // Increased from 20 - need more context before extraction\n longTermExtractionInterval: 10, // Increased from 5 - extract less frequently\n summaryModelType: 'TEXT_LARGE',\n summaryMaxTokens: 2500,\n summaryMaxNewMessages: 20, // Cap new messages in update to prevent context bloat\n };\n }\n\n static async start(runtime: IAgentRuntime): Promise<Service> {\n const service = new MemoryService(runtime);\n await service.initialize(runtime);\n return service;\n }\n\n async stop(): Promise<void> {\n // No cleanup needed for this service\n logger.info('MemoryService stopped');\n }\n\n async initialize(runtime: IAgentRuntime): Promise<void> {\n this.runtime = runtime;\n\n // Load configuration from runtime settings\n const threshold = runtime.getSetting('MEMORY_SUMMARIZATION_THRESHOLD');\n if (threshold) {\n this.memoryConfig.shortTermSummarizationThreshold = parseInt(threshold, 10);\n }\n\n const retainRecent = runtime.getSetting('MEMORY_RETAIN_RECENT');\n if (retainRecent) {\n this.memoryConfig.shortTermRetainRecent = parseInt(retainRecent, 10);\n }\n\n const summarizationInterval = runtime.getSetting('MEMORY_SUMMARIZATION_INTERVAL');\n if (summarizationInterval) {\n this.memoryConfig.shortTermSummarizationInterval = parseInt(summarizationInterval, 10);\n }\n\n const maxNewMessages = runtime.getSetting('MEMORY_MAX_NEW_MESSAGES');\n if (maxNewMessages) {\n this.memoryConfig.summaryMaxNewMessages = parseInt(maxNewMessages, 10);\n }\n\n const longTermEnabled = runtime.getSetting('MEMORY_LONG_TERM_ENABLED');\n // Only override default if explicitly set to 'false'\n if (longTermEnabled === 'false') {\n this.memoryConfig.longTermExtractionEnabled = false;\n } else if (longTermEnabled === 'true') {\n this.memoryConfig.longTermExtractionEnabled = true;\n }\n // Otherwise keep the default value (true)\n\n const confidenceThreshold = runtime.getSetting('MEMORY_CONFIDENCE_THRESHOLD');\n if (confidenceThreshold) {\n this.memoryConfig.longTermConfidenceThreshold = parseFloat(confidenceThreshold);\n }\n\n const extractionThreshold = runtime.getSetting('MEMORY_EXTRACTION_THRESHOLD');\n if (extractionThreshold) {\n this.memoryConfig.longTermExtractionThreshold = parseInt(extractionThreshold, 10);\n }\n\n const extractionInterval = runtime.getSetting('MEMORY_EXTRACTION_INTERVAL');\n if (extractionInterval) {\n this.memoryConfig.longTermExtractionInterval = parseInt(extractionInterval, 10);\n }\n\n logger.debug(\n {\n summarizationThreshold: this.memoryConfig.shortTermSummarizationThreshold,\n summarizationInterval: this.memoryConfig.shortTermSummarizationInterval,\n maxNewMessages: this.memoryConfig.summaryMaxNewMessages,\n retainRecent: this.memoryConfig.shortTermRetainRecent,\n longTermEnabled: this.memoryConfig.longTermExtractionEnabled,\n extractionThreshold: this.memoryConfig.longTermExtractionThreshold,\n extractionInterval: this.memoryConfig.longTermExtractionInterval,\n confidenceThreshold: this.memoryConfig.longTermConfidenceThreshold,\n },\n 'MemoryService initialized'\n );\n }\n\n /**\n * Get the Drizzle database instance\n */\n private getDb(): any {\n const db = (this.runtime as any).db;\n if (!db) {\n throw new Error('Database not available');\n }\n return db;\n }\n\n /**\n * Get configuration\n */\n getConfig(): MemoryConfig {\n return { ...this.memoryConfig };\n }\n\n /**\n * Update configuration\n */\n updateConfig(updates: Partial<MemoryConfig>): void {\n this.memoryConfig = { ...this.memoryConfig, ...updates };\n }\n\n /**\n * Track message count for a room\n */\n incrementMessageCount(roomId: UUID): number {\n const current = this.sessionMessageCounts.get(roomId) || 0;\n const newCount = current + 1;\n this.sessionMessageCounts.set(roomId, newCount);\n return newCount;\n }\n\n /**\n * Reset message count for a room\n */\n resetMessageCount(roomId: UUID): void {\n this.sessionMessageCounts.set(roomId, 0);\n }\n\n /**\n * Check if summarization is needed for a room\n */\n async shouldSummarize(roomId: UUID): Promise<boolean> {\n const count = await this.runtime.countMemories(roomId, false, 'messages');\n return count >= this.memoryConfig.shortTermSummarizationThreshold;\n }\n\n /**\n * Generate cache key for tracking extraction checkpoints per entity-room pair\n */\n private getExtractionKey(entityId: UUID, roomId: UUID): string {\n return `memory:extraction:${entityId}:${roomId}`;\n }\n\n /**\n * Get the last extraction checkpoint for an entity in a room\n * Uses the cache table via adapter\n */\n async getLastExtractionCheckpoint(entityId: UUID, roomId: UUID): Promise<number> {\n const key = this.getExtractionKey(entityId, roomId);\n\n // Check in-memory cache first\n const cached = this.lastExtractionCheckpoints.get(key);\n if (cached !== undefined) {\n return cached;\n }\n\n // Check database cache table via adapter\n try {\n const checkpoint = await this.runtime.getCache<number>(key);\n const messageCount = checkpoint ?? 0;\n\n // Cache it in memory for faster access\n this.lastExtractionCheckpoints.set(key, messageCount);\n\n return messageCount;\n } catch (error) {\n logger.warn({ error }, 'Failed to get extraction checkpoint from cache');\n return 0;\n }\n }\n\n /**\n * Set the last extraction checkpoint for an entity in a room\n * Uses the cache table via adapter\n */\n async setLastExtractionCheckpoint(\n entityId: UUID,\n roomId: UUID,\n messageCount: number\n ): Promise<void> {\n const key = this.getExtractionKey(entityId, roomId);\n\n // Update in-memory cache\n this.lastExtractionCheckpoints.set(key, messageCount);\n\n // Persist to database cache table via adapter\n try {\n await this.runtime.setCache(key, messageCount);\n logger.debug(\n `Set extraction checkpoint for ${entityId} in room ${roomId} at message count ${messageCount}`\n );\n } catch (error) {\n logger.error({ error }, 'Failed to persist extraction checkpoint to cache');\n }\n }\n\n /**\n * Check if long-term extraction should run based on message count and interval\n */\n async shouldRunExtraction(\n entityId: UUID,\n roomId: UUID,\n currentMessageCount: number\n ): Promise<boolean> {\n const threshold = this.memoryConfig.longTermExtractionThreshold;\n const interval = this.memoryConfig.longTermExtractionInterval;\n \n // Don't run extraction until we reach the minimum threshold\n if (currentMessageCount < threshold) {\n return false;\n }\n\n const lastCheckpoint = await this.getLastExtractionCheckpoint(entityId, roomId);\n\n // Calculate the current checkpoint (e.g., if interval=5: 20, 25, 30, 35...)\n const currentCheckpoint = Math.floor(currentMessageCount / interval) * interval;\n\n // Run if we're at or past a checkpoint and haven't processed this checkpoint yet\n const shouldRun = currentMessageCount >= threshold && currentCheckpoint > lastCheckpoint;\n\n logger.debug(\n {\n entityId,\n roomId,\n currentMessageCount,\n threshold,\n interval,\n lastCheckpoint,\n currentCheckpoint,\n shouldRun,\n },\n 'Extraction check'\n );\n\n return shouldRun;\n }\n\n /**\n * Store a long-term memory\n */\n async storeLongTermMemory(\n memory: Omit<LongTermMemory, 'id' | 'createdAt' | 'updatedAt'>\n ): Promise<LongTermMemory> {\n const db = this.getDb();\n\n const id = crypto.randomUUID() as UUID;\n const now = new Date();\n\n const newMemory: LongTermMemory = {\n id,\n createdAt: now,\n updatedAt: now,\n accessCount: 0,\n ...memory,\n };\n\n try {\n await db.insert(longTermMemories).values({\n id: newMemory.id,\n agentId: newMemory.agentId,\n entityId: newMemory.entityId,\n category: newMemory.category,\n content: newMemory.content,\n metadata: newMemory.metadata || {},\n embedding: newMemory.embedding,\n confidence: newMemory.confidence,\n source: newMemory.source,\n accessCount: newMemory.accessCount,\n createdAt: now,\n updatedAt: now,\n lastAccessedAt: newMemory.lastAccessedAt,\n });\n } catch (error) {\n logger.error({ error }, 'Failed to store long-term memory');\n throw error;\n }\n\n logger.info(`Stored long-term memory: ${newMemory.category} for entity ${newMemory.entityId}`);\n return newMemory;\n }\n\n /**\n * Retrieve long-term memories for an entity\n */\n async getLongTermMemories(\n entityId: UUID,\n category?: LongTermMemoryCategory,\n limit: number = 10\n ): Promise<LongTermMemory[]> {\n const db = this.getDb();\n\n const conditions = [\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId),\n ];\n\n if (category) {\n conditions.push(eq(longTermMemories.category, category));\n }\n\n const results = await db\n .select()\n .from(longTermMemories)\n .where(and(...conditions))\n .orderBy(desc(longTermMemories.confidence), desc(longTermMemories.updatedAt))\n .limit(limit);\n\n return results.map((row) => ({\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n entityId: row.entityId as UUID,\n category: row.category as LongTermMemoryCategory,\n content: row.content,\n metadata: row.metadata as Record<string, unknown>,\n embedding: row.embedding as number[],\n confidence: row.confidence as number,\n source: row.source as string,\n createdAt: row.createdAt,\n updatedAt: row.updatedAt,\n lastAccessedAt: row.lastAccessedAt,\n accessCount: row.accessCount as number,\n }));\n }\n\n /**\n * Update a long-term memory\n * Enforces multi-tenancy by verifying agentId and entityId\n */\n async updateLongTermMemory(\n id: UUID,\n entityId: UUID,\n updates: Partial<Omit<LongTermMemory, 'id' | 'agentId' | 'entityId' | 'createdAt'>>\n ): Promise<void> {\n const db = this.getDb();\n\n const updateData: any = {\n updatedAt: new Date(),\n };\n\n if (updates.content !== undefined) {\n updateData.content = updates.content;\n }\n\n if (updates.metadata !== undefined) {\n updateData.metadata = updates.metadata;\n }\n\n if (updates.confidence !== undefined) {\n updateData.confidence = updates.confidence;\n }\n\n if (updates.embedding !== undefined) {\n updateData.embedding = updates.embedding;\n }\n\n if (updates.lastAccessedAt !== undefined) {\n updateData.lastAccessedAt = updates.lastAccessedAt;\n }\n\n if (updates.accessCount !== undefined) {\n updateData.accessCount = updates.accessCount;\n }\n\n // Enforce multi-tenancy: only update if agentId and entityId match\n await db\n .update(longTermMemories)\n .set(updateData)\n .where(\n and(\n eq(longTermMemories.id, id),\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId)\n )\n );\n\n logger.info(`Updated long-term memory: ${id} for entity ${entityId}`);\n }\n\n /**\n * Delete a long-term memory\n * Enforces multi-tenancy by verifying agentId and entityId\n */\n async deleteLongTermMemory(id: UUID, entityId: UUID): Promise<void> {\n const db = this.getDb();\n\n // Enforce multi-tenancy: only delete if agentId and entityId match\n await db\n .delete(longTermMemories)\n .where(\n and(\n eq(longTermMemories.id, id),\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId)\n )\n );\n\n logger.info(`Deleted long-term memory: ${id} for entity ${entityId}`);\n }\n\n /**\n * Get the current session summary for a room (latest one)\n */\n async getCurrentSessionSummary(roomId: UUID): Promise<SessionSummary | null> {\n const db = this.getDb();\n\n const results = await db\n .select()\n .from(sessionSummaries)\n .where(\n and(eq(sessionSummaries.agentId, this.runtime.agentId), eq(sessionSummaries.roomId, roomId))\n )\n .orderBy(desc(sessionSummaries.updatedAt))\n .limit(1);\n\n if (results.length === 0) {\n return null;\n }\n\n const row = results[0];\n return {\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n roomId: row.roomId as UUID,\n entityId: row.entityId as UUID | undefined,\n summary: row.summary,\n messageCount: row.messageCount,\n lastMessageOffset: row.lastMessageOffset,\n startTime: row.startTime,\n endTime: row.endTime,\n topics: (row.topics as string[]) || [],\n metadata: row.metadata as Record<string, unknown>,\n embedding: row.embedding as number[],\n createdAt: row.createdAt,\n updatedAt: row.updatedAt,\n };\n }\n\n /**\n * Store a session summary (initial creation)\n */\n async storeSessionSummary(\n summary: Omit<SessionSummary, 'id' | 'createdAt' | 'updatedAt'>\n ): Promise<SessionSummary> {\n const db = this.getDb();\n\n const id = crypto.randomUUID() as UUID;\n const now = new Date();\n\n const newSummary: SessionSummary = {\n id,\n createdAt: now,\n updatedAt: now,\n ...summary,\n };\n\n await db.insert(sessionSummaries).values({\n id: newSummary.id,\n agentId: newSummary.agentId,\n roomId: newSummary.roomId,\n entityId: newSummary.entityId || null,\n summary: newSummary.summary,\n messageCount: newSummary.messageCount,\n lastMessageOffset: newSummary.lastMessageOffset,\n startTime: newSummary.startTime,\n endTime: newSummary.endTime,\n topics: newSummary.topics || [],\n metadata: newSummary.metadata || {},\n embedding: newSummary.embedding,\n createdAt: now,\n updatedAt: now,\n });\n\n logger.info(`Stored session summary for room ${newSummary.roomId}`);\n return newSummary;\n }\n\n /**\n * Update an existing session summary\n * Enforces multi-tenancy by verifying agentId\n */\n async updateSessionSummary(\n id: UUID,\n roomId: UUID,\n updates: Partial<Omit<SessionSummary, 'id' | 'agentId' | 'roomId' | 'createdAt' | 'updatedAt'>>\n ): Promise<void> {\n const db = this.getDb();\n\n const updateData: any = {\n updatedAt: new Date(),\n };\n\n if (updates.summary !== undefined) {\n updateData.summary = updates.summary;\n }\n\n if (updates.messageCount !== undefined) {\n updateData.messageCount = updates.messageCount;\n }\n\n if (updates.lastMessageOffset !== undefined) {\n updateData.lastMessageOffset = updates.lastMessageOffset;\n }\n\n if (updates.endTime !== undefined) {\n updateData.endTime = updates.endTime;\n }\n\n if (updates.topics !== undefined) {\n updateData.topics = updates.topics;\n }\n\n if (updates.metadata !== undefined) {\n updateData.metadata = updates.metadata;\n }\n\n if (updates.embedding !== undefined) {\n updateData.embedding = updates.embedding;\n }\n\n // Enforce multi-tenancy: only update if agentId and roomId match\n await db\n .update(sessionSummaries)\n .set(updateData)\n .where(\n and(\n eq(sessionSummaries.id, id),\n eq(sessionSummaries.agentId, this.runtime.agentId),\n eq(sessionSummaries.roomId, roomId)\n )\n );\n\n logger.info(`Updated session summary: ${id} for room ${roomId}`);\n }\n\n /**\n * Get session summaries for a room\n */\n async getSessionSummaries(roomId: UUID, limit: number = 5): Promise<SessionSummary[]> {\n const db = this.getDb();\n\n const results = await db\n .select()\n .from(sessionSummaries)\n .where(\n and(eq(sessionSummaries.agentId, this.runtime.agentId), eq(sessionSummaries.roomId, roomId))\n )\n .orderBy(desc(sessionSummaries.updatedAt))\n .limit(limit);\n\n return results.map((row) => ({\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n roomId: row.roomId as UUID,\n entityId: row.entityId as UUID | undefined,\n summary: row.summary,\n messageCount: row.messageCount,\n lastMessageOffset: row.lastMessageOffset,\n startTime: row.startTime,\n endTime: row.endTime,\n topics: (row.topics as string[]) || [],\n metadata: row.metadata as Record<string, unknown>,\n embedding: row.embedding as number[],\n createdAt: row.createdAt,\n updatedAt: row.updatedAt,\n }));\n }\n\n /**\n * Search long-term memories by semantic similarity (if embeddings are available)\n */\n async searchLongTermMemories(\n entityId: UUID,\n queryEmbedding: number[],\n limit: number = 5,\n matchThreshold: number = 0.7\n ): Promise<LongTermMemory[]> {\n if (!this.memoryConfig.longTermVectorSearchEnabled) {\n logger.warn('Vector search is not enabled, falling back to recent memories');\n return this.getLongTermMemories(entityId, undefined, limit);\n }\n\n const db = this.getDb();\n\n try {\n // Clean the vector to ensure all numbers are finite and properly formatted\n const cleanVector = queryEmbedding.map((n) =>\n Number.isFinite(n) ? Number(n.toFixed(6)) : 0\n );\n\n // Calculate similarity using Drizzle's cosineDistance\n const similarity = sql<number>`1 - (${cosineDistance(\n longTermMemories.embedding,\n cleanVector\n )})`;\n\n const conditions = [\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId),\n sql`${longTermMemories.embedding} IS NOT NULL`,\n ];\n\n // Add similarity threshold if specified\n if (matchThreshold > 0) {\n conditions.push(gte(similarity, matchThreshold));\n }\n\n const results = await db\n .select({\n memory: longTermMemories,\n similarity,\n })\n .from(longTermMemories)\n .where(and(...conditions))\n .orderBy(desc(similarity))\n .limit(limit);\n\n return results.map((row) => ({\n id: row.memory.id as UUID,\n agentId: row.memory.agentId as UUID,\n entityId: row.memory.entityId as UUID,\n category: row.memory.category as LongTermMemoryCategory,\n content: row.memory.content,\n metadata: row.memory.metadata as Record<string, unknown>,\n embedding: row.memory.embedding as number[],\n confidence: row.memory.confidence as number,\n source: row.memory.source as string,\n createdAt: row.memory.createdAt,\n updatedAt: row.memory.updatedAt,\n lastAccessedAt: row.memory.lastAccessedAt,\n accessCount: row.memory.accessCount as number,\n similarity: row.similarity,\n }));\n } catch (error) {\n logger.warn({ error }, 'Vector search failed, falling back to recent memories');\n return this.getLongTermMemories(entityId, undefined, limit);\n }\n }\n\n /**\n * Get all long-term memories formatted for context\n */\n async getFormattedLongTermMemories(entityId: UUID): Promise<string> {\n const memories = await this.getLongTermMemories(entityId, undefined, 20);\n\n if (memories.length === 0) {\n return '';\n }\n\n // Group by category\n const grouped = new Map<LongTermMemoryCategory, LongTermMemory[]>();\n\n for (const memory of memories) {\n if (!grouped.has(memory.category)) {\n grouped.set(memory.category, []);\n }\n grouped.get(memory.category)?.push(memory);\n }\n\n // Format each category\n const sections: string[] = [];\n\n for (const [category, categoryMemories] of grouped.entries()) {\n const categoryName = category\n .split('_')\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1))\n .join(' ');\n\n const items = categoryMemories.map((m) => `- ${m.content}`).join('\\n');\n sections.push(`**${categoryName}**:\\n${items}`);\n }\n\n return sections.join('\\n\\n');\n }\n}\n",
6
- "import { sql } from 'drizzle-orm';\nimport {\n pgTable,\n text,\n integer,\n jsonb,\n real,\n index,\n varchar,\n timestamp,\n} from 'drizzle-orm/pg-core';\n\n/**\n * Long-term memory storage table\n * Stores persistent facts about users across all conversations\n */\nexport const longTermMemories = pgTable(\n 'long_term_memories',\n {\n id: varchar('id', { length: 36 }).primaryKey(),\n agentId: varchar('agent_id', { length: 36 }).notNull(),\n entityId: varchar('entity_id', { length: 36 }).notNull(),\n category: text('category').notNull(),\n content: text('content').notNull(),\n metadata: jsonb('metadata'),\n embedding: real('embedding').array(),\n confidence: real('confidence').default(1.0),\n source: text('source'),\n createdAt: timestamp('created_at')\n .default(sql`now()`)\n .notNull(),\n updatedAt: timestamp('updated_at')\n .default(sql`now()`)\n .notNull(),\n lastAccessedAt: timestamp('last_accessed_at'),\n accessCount: integer('access_count').default(0),\n },\n (table) => ({\n agentEntityIdx: index('long_term_memories_agent_entity_idx').on(table.agentId, table.entityId),\n categoryIdx: index('long_term_memories_category_idx').on(table.category),\n confidenceIdx: index('long_term_memories_confidence_idx').on(table.confidence),\n createdAtIdx: index('long_term_memories_created_at_idx').on(table.createdAt),\n })\n);\n",
7
- "import { sql } from 'drizzle-orm';\nimport {\n pgTable,\n text,\n integer,\n jsonb,\n real,\n index,\n varchar,\n timestamp,\n} from 'drizzle-orm/pg-core';\n\n/**\n * Session summaries table\n * Stores condensed summaries of conversation sessions\n */\nexport const sessionSummaries = pgTable(\n 'session_summaries',\n {\n id: varchar('id', { length: 36 }).primaryKey(),\n agentId: varchar('agent_id', { length: 36 }).notNull(),\n roomId: varchar('room_id', { length: 36 }).notNull(),\n entityId: varchar('entity_id', { length: 36 }),\n summary: text('summary').notNull(),\n messageCount: integer('message_count').notNull(),\n lastMessageOffset: integer('last_message_offset').notNull().default(0),\n startTime: timestamp('start_time').notNull(),\n endTime: timestamp('end_time').notNull(),\n topics: jsonb('topics'),\n metadata: jsonb('metadata'),\n embedding: real('embedding').array(),\n createdAt: timestamp('created_at')\n .default(sql`now()`)\n .notNull(),\n updatedAt: timestamp('updated_at')\n .default(sql`now()`)\n .notNull(),\n },\n (table) => ({\n agentRoomIdx: index('session_summaries_agent_room_idx').on(table.agentId, table.roomId),\n entityIdx: index('session_summaries_entity_idx').on(table.entityId),\n startTimeIdx: index('session_summaries_start_time_idx').on(table.startTime),\n })\n);\n",
8
- "import { sql } from 'drizzle-orm';\nimport { pgTable, text, integer, real, index, varchar, timestamp } from 'drizzle-orm/pg-core';\n\n/**\n * Memory access logs (optional - for tracking and improving memory retrieval)\n */\nexport const memoryAccessLogs = pgTable(\n 'memory_access_logs',\n {\n id: varchar('id', { length: 36 }).primaryKey(),\n agentId: varchar('agent_id', { length: 36 }).notNull(),\n memoryId: varchar('memory_id', { length: 36 }).notNull(),\n memoryType: text('memory_type').notNull(), // 'long_term' or 'session_summary'\n accessedAt: timestamp('accessed_at')\n .default(sql`now()`)\n .notNull(),\n roomId: varchar('room_id', { length: 36 }),\n relevanceScore: real('relevance_score'),\n wasUseful: integer('was_useful'), // 1 = useful, 0 = not useful, null = unknown\n },\n (table) => ({\n memoryIdx: index('memory_access_logs_memory_idx').on(table.memoryId),\n agentIdx: index('memory_access_logs_agent_idx').on(table.agentId),\n accessedAtIdx: index('memory_access_logs_accessed_at_idx').on(table.accessedAt),\n })\n);\n",
9
- "import {\n type IAgentRuntime,\n type Memory,\n type Evaluator,\n logger,\n ModelType,\n composePromptFromState,\n type UUID,\n} from \"@elizaos/core\";\nimport { MemoryService } from \"../services/memory-service\";\nimport type { SummaryResult } from \"../types/index\";\n\n/**\n * Helper function to get dialogue messages count (excluding action results)\n * This matches the filtering logic in short-term-memory provider\n */\nasync function getDialogueMessageCount(\n runtime: IAgentRuntime,\n roomId: UUID\n): Promise<number> {\n // We need to fetch messages to filter them properly\n // Fetch a reasonable batch to check\n const messages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: 100, // Check last 100 messages\n unique: false,\n });\n\n const dialogueMessages = messages.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n );\n\n return dialogueMessages.length;\n}\n\n/**\n * Template for generating initial conversation summary\n */\nconst initialSummarizationTemplate = `# Task: Summarize Conversation\n\nYou are analyzing a conversation to create a concise summary that captures the key points, topics, and important details.\n\n# Recent Messages\n{{recentMessages}}\n\n# Instructions\nGenerate a summary that:\n1. Captures the main topics discussed\n2. Highlights key information shared\n3. Notes any decisions made or questions asked\n4. Maintains context for future reference\n5. Is concise but comprehensive\n\n**IMPORTANT**: Keep the summary under 2500 tokens. Be comprehensive but concise.\n\nAlso extract:\n- **Topics**: List of main topics discussed (comma-separated)\n- **Key Points**: Important facts or decisions (bullet points)\n\nRespond in this XML format:\n<summary>\n <text>Your comprehensive summary here</text>\n <topics>topic1, topic2, topic3</topics>\n <keyPoints>\n <point>First key point</point>\n <point>Second key point</point>\n </keyPoints>\n</summary>`;\n\n/**\n * Template for updating/condensing an existing summary\n */\nconst updateSummarizationTemplate = `# Task: Update and Condense Conversation Summary\n\nYou are updating an existing conversation summary with new messages, while keeping the total summary concise.\n\n# Existing Summary\n{{existingSummary}}\n\n# Existing Topics\n{{existingTopics}}\n\n# New Messages Since Last Summary\n{{newMessages}}\n\n# Instructions\nUpdate the summary by:\n1. Merging the existing summary with insights from the new messages\n2. Removing redundant or less important details to stay under the token limit\n3. Keeping the most important context and decisions\n4. Adding new topics if they emerge\n5. **CRITICAL**: Keep the ENTIRE updated summary under 2500 tokens\n\nThe goal is a rolling summary that captures the essence of the conversation without growing indefinitely.\n\nRespond in this XML format:\n<summary>\n <text>Your updated and condensed summary here</text>\n <topics>topic1, topic2, topic3</topics>\n <keyPoints>\n <point>First key point</point>\n <point>Second key point</point>\n </keyPoints>\n</summary>`;\n\n/**\n * Parse XML summary response\n */\nfunction parseSummaryXML(xml: string): SummaryResult {\n const summaryMatch = xml.match(/<text>([\\s\\S]*?)<\\/text>/);\n const topicsMatch = xml.match(/<topics>([\\s\\S]*?)<\\/topics>/);\n const keyPointsMatches = xml.matchAll(/<point>([\\s\\S]*?)<\\/point>/g);\n\n const summary = summaryMatch\n ? summaryMatch[1].trim()\n : \"Summary not available\";\n const topics = topicsMatch\n ? topicsMatch[1]\n .split(\",\")\n .map((t) => t.trim())\n .filter(Boolean)\n : [];\n const keyPoints = Array.from(keyPointsMatches).map((match) =>\n match[1].trim()\n );\n\n return { summary, topics, keyPoints };\n}\n\n/**\n * Short-term Memory Summarization Evaluator\n *\n * Automatically generates and updates conversation summaries when conversations\n * exceed the configured threshold (default: 16 messages).\n *\n * BEHAVIOR:\n * - Monitors message count per room\n * - Creates initial summary when count >= threshold (e.g., 16 messages)\n * - Updates summary at regular intervals (e.g., every 10 new messages)\n * - Condenses existing summary with new messages to stay under token limit\n * - Tracks offset to avoid re-processing messages\n * - Caps new messages per update to prevent context bloat (default: 20)\n *\n * OPTIMIZATION:\n * - Only triggers LLM when crossing threshold or interval boundaries\n * - Processes only NEW messages since last update\n * - Maintains rolling summary (fixed size, not ever-growing)\n * - LLM is instructed to merge and condense, keeping under 2500 tokens\n *\n * INTEGRATION:\n * Works with shortTermMemoryProvider which:\n * - Shows full conversation when < threshold (no summarization needed)\n * - Shows summaries + recent messages when >= threshold (optimized context)\n *\n * This creates an adaptive system that starts with full context and seamlessly\n * transitions to efficient summarization as conversations grow.\n */\nexport const summarizationEvaluator: Evaluator = {\n name: \"MEMORY_SUMMARIZATION\",\n description:\n \"Automatically summarizes conversations to optimize context usage\",\n similes: [\n \"CONVERSATION_SUMMARY\",\n \"CONTEXT_COMPRESSION\",\n \"MEMORY_OPTIMIZATION\",\n ],\n alwaysRun: true,\n\n validate: async (\n runtime: IAgentRuntime,\n message: Memory\n ): Promise<boolean> => {\n // Only run after actual messages (not during generation or on empty messages)\n if (!message.content?.text) {\n return false;\n }\n\n const memoryService = runtime.getService(\"memory\") as MemoryService | null;\n if (!memoryService) {\n return false;\n }\n\n const config = memoryService.getConfig();\n\n // Get dialogue message count (excluding action results)\n const currentDialogueCount = await getDialogueMessageCount(\n runtime,\n message.roomId\n );\n\n // Get existing summary to check if we need initial or update\n const existingSummary = await memoryService.getCurrentSessionSummary(\n message.roomId\n );\n\n if (!existingSummary) {\n // No summary yet - create initial summary when dialogue threshold is reached\n const shouldSummarize =\n currentDialogueCount >= config.shortTermSummarizationThreshold;\n return shouldSummarize;\n } else {\n // Summary exists - check if we have enough new dialogue messages since last update\n const newDialogueCount =\n currentDialogueCount - existingSummary.lastMessageOffset;\n const shouldUpdate =\n newDialogueCount >= config.shortTermSummarizationInterval;\n return shouldUpdate;\n }\n },\n\n handler: async (runtime: IAgentRuntime, message: Memory): Promise<void> => {\n const memoryService = runtime.getService(\"memory\") as MemoryService;\n if (!memoryService) {\n logger.error(\"MemoryService not found\");\n return;\n }\n\n const config = memoryService.getConfig();\n const { roomId } = message;\n\n try {\n logger.info(`Starting summarization for room ${roomId}`);\n\n // Get the current summary (if any)\n const existingSummary = await memoryService.getCurrentSessionSummary(\n roomId\n );\n const lastOffset = existingSummary?.lastMessageOffset || 0;\n\n // Get all messages and filter to dialogue only\n const allMessages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: 1000, // Get a large batch to ensure we have all relevant messages\n unique: false,\n });\n\n // Filter to dialogue messages only (matching provider logic)\n const allDialogueMessages = allMessages.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n );\n\n // Get total dialogue message count\n const totalDialogueCount = allDialogueMessages.length;\n\n // Calculate how many new dialogue messages we have since last summary\n const newDialogueCount = totalDialogueCount - lastOffset;\n\n if (newDialogueCount === 0) {\n logger.debug(\"No new dialogue messages to summarize\");\n return;\n }\n\n // Cap the number of new messages to prevent context bloat\n const maxNewMessages = config.summaryMaxNewMessages || 50;\n const messagesToProcess = Math.min(newDialogueCount, maxNewMessages);\n\n // Log if we're hitting the cap\n if (newDialogueCount > maxNewMessages) {\n logger.warn(\n `Capping new dialogue messages at ${maxNewMessages} (${newDialogueCount} available). Oldest messages will be skipped.`\n );\n }\n\n // Sort all dialogue messages by timestamp\n const sortedDialogueMessages = allDialogueMessages.sort(\n (a, b) => (a.createdAt || 0) - (b.createdAt || 0)\n );\n\n // Get new dialogue messages since last offset\n const newDialogueMessages = sortedDialogueMessages.slice(\n lastOffset,\n lastOffset + messagesToProcess\n );\n\n if (newDialogueMessages.length === 0) {\n logger.debug(\"No new dialogue messages retrieved after filtering\");\n return;\n }\n\n // Format messages for summarization\n const formattedMessages = newDialogueMessages\n .map((msg) => {\n const sender =\n msg.entityId === runtime.agentId ? runtime.character.name : \"User\";\n return `${sender}: ${msg.content.text || \"[non-text message]\"}`;\n })\n .join(\"\\n\");\n\n // Generate or update summary using LLM\n const state = await runtime.composeState(message);\n let prompt: string;\n let template: string;\n\n if (existingSummary) {\n // Update existing summary\n template = updateSummarizationTemplate;\n prompt = composePromptFromState({\n state: {\n ...state,\n existingSummary: existingSummary.summary,\n existingTopics: existingSummary.topics?.join(\", \") || \"None\",\n newMessages: formattedMessages,\n },\n template,\n });\n } else {\n // Create initial summary - use ALL dialogue messages for comprehensive initial summary\n const initialMessages = sortedDialogueMessages\n .map((msg) => {\n const sender =\n msg.entityId === runtime.agentId\n ? runtime.character.name\n : \"User\";\n return `${sender}: ${msg.content.text || \"[non-text message]\"}`;\n })\n .join(\"\\n\");\n\n template = initialSummarizationTemplate;\n prompt = composePromptFromState({\n state: {\n ...state,\n recentMessages: initialMessages,\n },\n template,\n });\n }\n\n const response = await runtime.useModel(ModelType.TEXT_LARGE, {\n prompt,\n maxTokens: config.summaryMaxTokens || 2500,\n });\n\n const summaryResult = parseSummaryXML(response);\n\n logger.info(\n `${\n existingSummary ? \"Updated\" : \"Generated\"\n } summary: ${summaryResult.summary.substring(0, 100)}...`\n );\n\n // Calculate new offset based on dialogue messages processed\n const newOffset = lastOffset + newDialogueMessages.length;\n\n // Get timing info\n const firstMessage = newDialogueMessages[0];\n const lastMessage = newDialogueMessages[newDialogueMessages.length - 1];\n\n const startTime = existingSummary\n ? existingSummary.startTime\n : firstMessage?.createdAt && firstMessage.createdAt > 0\n ? new Date(firstMessage.createdAt)\n : new Date();\n const endTime =\n lastMessage?.createdAt && lastMessage.createdAt > 0\n ? new Date(lastMessage.createdAt)\n : new Date();\n\n if (existingSummary) {\n // Update existing summary\n await memoryService.updateSessionSummary(existingSummary.id, roomId, {\n summary: summaryResult.summary,\n messageCount:\n existingSummary.messageCount + newDialogueMessages.length,\n lastMessageOffset: newOffset,\n endTime,\n topics: summaryResult.topics,\n metadata: {\n keyPoints: summaryResult.keyPoints,\n },\n });\n\n logger.info(\n `Updated summary for room ${roomId}: ${newDialogueMessages.length} new dialogue messages processed (offset: ${lastOffset} → ${newOffset})`\n );\n } else {\n // Create new summary - offset is total dialogue count\n await memoryService.storeSessionSummary({\n agentId: runtime.agentId,\n roomId,\n entityId:\n message.entityId !== runtime.agentId ? message.entityId : undefined,\n summary: summaryResult.summary,\n messageCount: totalDialogueCount,\n lastMessageOffset: totalDialogueCount,\n startTime,\n endTime,\n topics: summaryResult.topics,\n metadata: {\n keyPoints: summaryResult.keyPoints,\n },\n });\n\n logger.info(\n `Created new summary for room ${roomId}: ${totalDialogueCount} dialogue messages summarized (offset: 0 → ${totalDialogueCount})`\n );\n }\n\n // Note: We do NOT delete messages - they stay in the database\n // The offset tracks what dialogue messages have been summarized\n } catch (error) {\n logger.error({ error }, \"Error during summarization:\");\n }\n },\n\n examples: [],\n};\n",
10
- "import {\n type IAgentRuntime,\n type Memory,\n type Evaluator,\n logger,\n ModelType,\n composePromptFromState,\n} from \"@elizaos/core\";\nimport { MemoryService } from \"../services/memory-service\";\nimport { LongTermMemoryCategory, type MemoryExtraction } from \"../types/index\";\n\n/**\n * Template for extracting long-term memories using cognitive science memory types\n */\nconst extractionTemplate = `# Task: Extract Long-Term Memory (Strict Criteria)\n\nYou are analyzing a conversation to extract ONLY the most critical, persistent information about the user using cognitive science memory categories.\n\n# Recent Messages\n{{recentMessages}}\n\n# Current Long-Term Memories\n{{existingMemories}}\n\n# Memory Categories (Based on Cognitive Science)\n\n## 1. EPISODIC Memory\nPersonal experiences and specific events with temporal/spatial context.\n**Examples:**\n- \"User completed migration project from MongoDB to PostgreSQL in Q2 2024\"\n- \"User encountered authentication bug in production on March 15th\"\n- \"User had a negative experience with Docker networking in previous job\"\n\n**Requirements:**\n- Must include WHO did WHAT, WHEN/WHERE\n- Must be a specific, concrete event (not a pattern)\n- Must have significant impact or relevance to future work\n\n## 2. SEMANTIC Memory\nGeneral facts, concepts, knowledge, and established truths about the user.\n**Examples:**\n- \"User is a senior backend engineer with 8 years experience\"\n- \"User specializes in distributed systems and microservices architecture\"\n- \"User's primary programming language is TypeScript\"\n- \"User works at Acme Corp as technical lead\"\n\n**Requirements:**\n- Must be factual, timeless information\n- Must be explicitly stated or demonstrated conclusively\n- No speculation or inference from single instances\n- Core identity, expertise, or knowledge only\n\n## 3. PROCEDURAL Memory\nSkills, workflows, methodologies, and how-to knowledge.\n**Examples:**\n- \"User follows strict TDD workflow: write tests first, then implementation\"\n- \"User prefers git rebase over merge to maintain linear history\"\n- \"User's debugging process: check logs → reproduce locally → binary search\"\n- \"User always writes JSDoc comments before implementing functions\"\n\n**Requirements:**\n- Must describe HOW user does something\n- Must be a repeated, consistent pattern (seen 3+ times or explicitly stated as standard practice)\n- Must be a workflow, methodology, or skill application\n- Not one-off preferences\n\n# ULTRA-STRICT EXTRACTION CRITERIA\n\n## ✅ DO EXTRACT (Only These):\n\n**EPISODIC:**\n- Significant completed projects or milestones\n- Important bugs, incidents, or problems encountered\n- Major decisions made with lasting impact\n- Formative experiences that shape future work\n\n**SEMANTIC:**\n- Professional identity (role, title, company)\n- Core expertise and specializations (stated explicitly or demonstrated conclusively)\n- Primary languages, frameworks, or tools (not exploratory use)\n- Established facts about their work context\n\n**PROCEDURAL:**\n- Consistent workflows demonstrated 3+ times or explicitly stated\n- Standard practices user always follows\n- Methodology preferences with clear rationale\n- Debugging, testing, or development processes\n\n## ❌ NEVER EXTRACT:\n\n- **One-time requests or tasks** (e.g., \"can you generate an image\", \"help me debug this\")\n- **Casual conversations** without lasting significance\n- **Exploratory questions** (e.g., \"how does X work?\")\n- **Temporary context** (current bug, today's task)\n- **Preferences from single occurrence** (e.g., user asked for code once)\n- **Social pleasantries** (thank you, greetings)\n- **Testing or experimentation** (trying out a feature)\n- **Common patterns everyone has** (likes clear explanations)\n- **Situational information** (working on feature X today)\n- **Opinions without persistence** (single complaint, isolated praise)\n- **General knowledge** (not specific to user)\n\n# Quality Gates (ALL Must Pass)\n\n1. **Significance Test**: Will this matter in 3+ months?\n2. **Specificity Test**: Is this concrete and actionable?\n3. **Evidence Test**: Is there strong evidence (3+ instances OR explicit self-identification)?\n4. **Uniqueness Test**: Is this specific to THIS user (not generic)?\n5. **Confidence Test**: Confidence must be >= 0.85 (be VERY conservative)\n6. **Non-Redundancy Test**: Does this add NEW information not in existing memories?\n\n# Confidence Scoring (Be Conservative)\n\n- **0.95-1.0**: User explicitly stated as core identity/practice AND demonstrated multiple times\n- **0.85-0.94**: User explicitly stated OR consistently demonstrated 5+ times\n- **0.75-0.84**: Strong pattern (3-4 instances) with supporting context\n- **Below 0.75**: DO NOT EXTRACT (insufficient evidence)\n\n# Critical Instructions\n\n1. **Default to NOT extracting** - When in doubt, skip it\n2. **Require overwhelming evidence** - One or two mentions is NOT enough\n3. **Focus on what's PERSISTENT** - Not what's temporary or situational\n4. **Verify against existing memories** - Don't duplicate or contradict\n5. **Maximum 2-3 extractions per run** - Quality over quantity\n\n**If there are no qualifying facts (which is common), respond with <memories></memories>**\n\n# Response Format\n\n<memories>\n <memory>\n <category>semantic</category>\n <content>User is a senior TypeScript developer with 8 years of backend experience</content>\n <confidence>0.95</confidence>\n </memory>\n <memory>\n <category>procedural</category>\n <content>User follows TDD workflow: writes tests before implementation, runs tests after each change</content>\n <confidence>0.88</confidence>\n </memory>\n <memory>\n <category>episodic</category>\n <content>User led database migration from MongoDB to PostgreSQL for payment system in Q2 2024</content>\n <confidence>0.92</confidence>\n </memory>\n</memories>`;\n\n/**\n * Parse XML memory extraction response\n */\nfunction parseMemoryExtractionXML(xml: string): MemoryExtraction[] {\n const memoryMatches = xml.matchAll(\n /<memory>[\\s\\S]*?<category>(.*?)<\\/category>[\\s\\S]*?<content>(.*?)<\\/content>[\\s\\S]*?<confidence>(.*?)<\\/confidence>[\\s\\S]*?<\\/memory>/g\n );\n\n const extractions: MemoryExtraction[] = [];\n\n for (const match of memoryMatches) {\n const category = match[1].trim() as LongTermMemoryCategory;\n const content = match[2].trim();\n const confidence = parseFloat(match[3].trim());\n\n // Validate category\n if (!Object.values(LongTermMemoryCategory).includes(category)) {\n logger.warn(`Invalid memory category: ${category}`);\n continue;\n }\n\n if (content && !isNaN(confidence)) {\n extractions.push({ category, content, confidence });\n }\n }\n\n return extractions;\n}\n\n/**\n * Long-term Memory Extraction Evaluator\n *\n * Analyzes conversations to extract persistent facts about users that should be remembered\n * across all future conversations.\n */\nexport const longTermExtractionEvaluator: Evaluator = {\n name: \"LONG_TERM_MEMORY_EXTRACTION\",\n description: \"Extracts long-term facts about users from conversations\",\n similes: [\"MEMORY_EXTRACTION\", \"FACT_LEARNING\", \"USER_PROFILING\"],\n alwaysRun: true,\n\n validate: async (\n runtime: IAgentRuntime,\n message: Memory\n ): Promise<boolean> => {\n // Only run on user messages (not agent's own)\n if (message.entityId === runtime.agentId) {\n return false;\n }\n\n if (!message.content?.text) {\n return false;\n }\n\n const memoryService = runtime.getService(\"memory\") as MemoryService | null;\n if (!memoryService) {\n return false;\n }\n\n const config = memoryService.getConfig();\n if (!config.longTermExtractionEnabled) {\n logger.debug(\"Long-term memory extraction is disabled\");\n return false;\n }\n\n // Count total messages from this entity in this room\n const currentMessageCount = await runtime.countMemories(\n message.roomId,\n false,\n \"messages\"\n );\n\n const shouldRun = await memoryService.shouldRunExtraction(\n message.entityId,\n message.roomId,\n currentMessageCount\n );\n return shouldRun;\n },\n\n handler: async (runtime: IAgentRuntime, message: Memory): Promise<void> => {\n const memoryService = runtime.getService(\"memory\") as MemoryService;\n if (!memoryService) {\n logger.error(\"MemoryService not found\");\n return;\n }\n\n const config = memoryService.getConfig();\n const { entityId, roomId } = message;\n\n try {\n logger.info(`Extracting long-term memories for entity ${entityId}`);\n\n // Get recent conversation context\n const recentMessages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: 20,\n unique: false,\n });\n\n const formattedMessages = recentMessages\n .sort((a, b) => (a.createdAt || 0) - (b.createdAt || 0))\n .map((msg) => {\n const sender =\n msg.entityId === runtime.agentId ? runtime.character.name : \"User\";\n return `${sender}: ${msg.content.text || \"[non-text message]\"}`;\n })\n .join(\"\\n\");\n\n // Get existing long-term memories\n const existingMemories = await memoryService.getLongTermMemories(\n entityId,\n undefined,\n 30\n );\n const formattedExisting =\n existingMemories.length > 0\n ? existingMemories\n .map(\n (m) =>\n `[${m.category}] ${m.content} (confidence: ${m.confidence})`\n )\n .join(\"\\n\")\n : \"None yet\";\n\n // Generate extraction using LLM\n const state = await runtime.composeState(message);\n const prompt = composePromptFromState({\n state: {\n ...state,\n recentMessages: formattedMessages,\n existingMemories: formattedExisting,\n },\n template: extractionTemplate,\n });\n\n const response = await runtime.useModel(ModelType.TEXT_LARGE, {\n prompt,\n });\n\n const extractions = parseMemoryExtractionXML(response);\n\n logger.info(`Extracted ${extractions.length} long-term memories`);\n\n // Store each extracted memory\n for (const extraction of extractions) {\n // Apply stricter confidence threshold (0.85 minimum)\n if (\n extraction.confidence >=\n Math.max(config.longTermConfidenceThreshold, 0.85)\n ) {\n await memoryService.storeLongTermMemory({\n agentId: runtime.agentId,\n entityId,\n category: extraction.category,\n content: extraction.content,\n confidence: extraction.confidence,\n source: \"conversation\",\n metadata: {\n roomId,\n extractedAt: new Date().toISOString(),\n },\n });\n\n logger.info(\n `Stored long-term memory: [${\n extraction.category\n }] ${extraction.content.substring(0, 50)}...`\n );\n } else {\n logger.debug(\n `Skipped low-confidence memory: ${\n extraction.content\n } (confidence: ${extraction.confidence}, threshold: ${Math.max(\n config.longTermConfidenceThreshold,\n 0.85\n )})`\n );\n }\n }\n\n // Update the extraction checkpoint after successful extraction\n const currentMessageCount = await runtime.countMemories(\n roomId,\n false,\n \"messages\"\n );\n await memoryService.setLastExtractionCheckpoint(\n entityId,\n roomId,\n currentMessageCount\n );\n logger.debug(\n `Updated extraction checkpoint to ${currentMessageCount} for entity ${entityId} in room ${roomId}`\n );\n } catch (error) {\n logger.error({ error }, \"Error during long-term memory extraction:\");\n }\n },\n\n examples: [],\n};\n",
11
- "import type { UUID } from '@elizaos/core';\n\n/**\n * Categories of long-term memory based on cognitive science\n * \n * Following the widely accepted classification of human long-term memory:\n * - EPISODIC: Personal experiences and events (what happened, when, where)\n * - SEMANTIC: Facts, concepts, and knowledge (what things mean)\n * - PROCEDURAL: Skills and how-to knowledge (how to do things)\n */\nexport enum LongTermMemoryCategory {\n EPISODIC = 'episodic', // Specific events, experiences, and interactions (e.g., \"User worked on bug #123 last Tuesday\")\n SEMANTIC = 'semantic', // General facts, concepts, and knowledge (e.g., \"User is a Python developer\", \"User prefers async/await\")\n PROCEDURAL = 'procedural', // Skills, workflows, and how-to knowledge (e.g., \"User follows TDD workflow\", \"User uses git rebase instead of merge\")\n}\n\n/**\n * Long-term memory entry\n */\nexport interface LongTermMemory {\n id: UUID;\n agentId: UUID;\n entityId: UUID; // The user/entity this memory is about\n category: LongTermMemoryCategory;\n content: string; // The actual memory content\n metadata?: Record<string, unknown>; // Additional structured data\n embedding?: number[]; // Vector embedding for semantic search\n confidence?: number; // Confidence score (0-1)\n source?: string; // Where this memory came from (conversation, manual, etc.)\n createdAt: Date;\n updatedAt: Date;\n lastAccessedAt?: Date;\n accessCount?: number;\n similarity?: number; // Optional similarity score from vector search\n}\n\n/**\n * Short-term memory session summary\n */\nexport interface SessionSummary {\n id: UUID;\n agentId: UUID;\n roomId: UUID;\n entityId?: UUID; // Optional: specific user in the session\n summary: string; // The summarized conversation\n messageCount: number; // Number of messages summarized\n lastMessageOffset: number; // Index of last summarized message (for pagination)\n startTime: Date; // Timestamp of first message\n endTime: Date; // Timestamp of last message\n topics?: string[]; // Main topics discussed\n metadata?: Record<string, unknown>;\n embedding?: number[]; // Vector embedding of the summary\n createdAt: Date;\n updatedAt: Date; // Track when summary was last updated\n}\n\n/**\n * Configuration for memory plugin\n */\nexport interface MemoryConfig {\n // Short-term memory settings\n shortTermSummarizationThreshold: number; // Messages count before summarization\n shortTermRetainRecent: number; // Number of recent messages to keep after summarization\n shortTermSummarizationInterval: number; // Update summary every N messages after threshold (e.g., 10)\n\n // Long-term memory settings\n longTermExtractionEnabled: boolean;\n longTermVectorSearchEnabled: boolean;\n longTermConfidenceThreshold: number; // Minimum confidence to store\n longTermExtractionThreshold: number; // Minimum messages before starting extraction (default 20)\n longTermExtractionInterval: number; // Run extraction every N messages after threshold (e.g., 5, 10, 15...)\n\n // Summarization settings\n summaryModelType?: string;\n summaryMaxTokens?: number;\n summaryMaxNewMessages?: number; // Max new messages to include in update (prevents context bloat)\n}\n\n/**\n * Memory extraction result from evaluator\n */\nexport interface MemoryExtraction {\n category: LongTermMemoryCategory;\n content: string;\n confidence: number;\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Summary generation result\n */\nexport interface SummaryResult {\n summary: string;\n topics: string[];\n keyPoints: string[];\n}\n",
12
- "import {\n type IAgentRuntime,\n type Memory,\n type Provider,\n type State,\n logger,\n addHeader,\n} from '@elizaos/core';\nimport { MemoryService } from '../services/memory-service';\n\n/**\n * Long-term Memory Provider\n *\n * Provides persistent facts about the user that have been learned across\n * all conversations. This includes:\n * - User identity and roles\n * - Domain expertise\n * - Preferences\n * - Goals and projects\n * - Custom definitions\n * - Behavioral patterns\n *\n * This provider enriches the context with relevant long-term information\n * to make the agent's responses more personalized and contextually aware.\n */\nexport const longTermMemoryProvider: Provider = {\n name: 'LONG_TERM_MEMORY',\n description: 'Persistent facts and preferences about the user',\n position: 50, // Run early to establish user context\n\n get: async (runtime: IAgentRuntime, message: Memory, _state: State) => {\n try {\n const memoryService = runtime.getService('memory') as MemoryService | null;\n if (!memoryService) {\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n\n const { entityId } = message;\n\n // Skip for agent's own messages\n if (entityId === runtime.agentId) {\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n\n // Get long-term memories for this entity\n const memories = await memoryService.getLongTermMemories(entityId, undefined, 25);\n\n if (memories.length === 0) {\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n\n // Format memories using the service's built-in formatter\n const formattedMemories = await memoryService.getFormattedLongTermMemories(entityId);\n\n const text = addHeader('# What I Know About You', formattedMemories);\n\n // Create a summary of memory categories for quick reference\n const categoryCounts = new Map<string, number>();\n for (const memory of memories) {\n const count = categoryCounts.get(memory.category) || 0;\n categoryCounts.set(memory.category, count + 1);\n }\n\n const categoryList = Array.from(categoryCounts.entries())\n .map(([cat, count]) => `${cat}: ${count}`)\n .join(', ');\n\n return {\n data: {\n memories,\n categoryCounts: Object.fromEntries(categoryCounts),\n },\n values: {\n longTermMemories: text,\n memoryCategories: categoryList,\n },\n text,\n };\n } catch (error) {\n logger.error({ error }, 'Error in longTermMemoryProvider:');\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n },\n};\n",
13
- "import {\n type IAgentRuntime,\n type Memory,\n type Provider,\n type State,\n addHeader,\n logger,\n} from '@elizaos/core';\nimport { MemoryService } from '../services/memory-service';\n\n/**\n * Context Summary Provider\n *\n * Provides summarized context from previous conversations.\n * Returns session summaries with and without topics for flexible usage.\n *\n * Values returned:\n * - sessionSummaries: Summary text only (without topics)\n * - sessionSummariesWithTopics: Summary text with topics included\n */\nexport const contextSummaryProvider: Provider = {\n name: 'SUMMARIZED_CONTEXT',\n description: 'Provides summarized context from previous conversations',\n position: 96,\n\n get: async (runtime: IAgentRuntime, message: Memory, _state: State) => {\n try {\n const memoryService = runtime.getService('memory') as MemoryService | null;\n const { roomId } = message;\n\n // If no memory service, return empty\n if (!memoryService) {\n return {\n data: {\n summary: null,\n },\n values: {\n sessionSummaries: '',\n sessionSummariesWithTopics: '',\n },\n text: '',\n };\n }\n\n // Get current session summary\n const currentSummary = await memoryService.getCurrentSessionSummary(roomId);\n\n if (!currentSummary) {\n return {\n data: {\n summary: null,\n },\n values: {\n sessionSummaries: '',\n sessionSummariesWithTopics: '',\n },\n text: '',\n };\n }\n\n // Format summary without topics\n const messageRange = `${currentSummary.messageCount} messages`;\n const timeRange = new Date(currentSummary.startTime).toLocaleDateString();\n\n let summaryOnly = `**Previous Conversation** (${messageRange}, ${timeRange})\\n`;\n summaryOnly += currentSummary.summary;\n\n // Format summary with topics\n let summaryWithTopics = summaryOnly;\n if (currentSummary.topics && currentSummary.topics.length > 0) {\n summaryWithTopics += `\\n*Topics: ${currentSummary.topics.join(', ')}*`;\n }\n\n const sessionSummaries = addHeader('# Conversation Summary', summaryOnly);\n const sessionSummariesWithTopics = addHeader('# Conversation Summary', summaryWithTopics);\n\n return {\n data: {\n summary: currentSummary,\n },\n values: {\n sessionSummaries,\n sessionSummariesWithTopics,\n },\n text: sessionSummariesWithTopics,\n };\n } catch (error) {\n logger.error({ error }, 'Error in contextSummaryProvider:');\n return {\n data: {\n summary: null,\n },\n values: {\n sessionSummaries: '',\n sessionSummariesWithTopics: '',\n },\n text: '',\n };\n }\n },\n};\n",
14
- "import {\n addHeader,\n ChannelType,\n CustomMetadata,\n formatMessages,\n formatPosts,\n getEntityDetails,\n type Entity,\n type IAgentRuntime,\n type Memory,\n type Provider,\n type State,\n logger,\n} from \"@elizaos/core\";\nimport { MemoryService } from \"../services/memory-service\";\n\n/**\n * Recent Messages Provider\n *\n * Provides recent conversation messages with detailed context.\n * Fetches the most recent unsummarized messages from the conversation.\n *\n * Values returned:\n * - recentMessages: Formatted recent messages\n * - conversationLog: Simple timestamped conversation log\n * - conversationLogWithAgentThoughts: Conversation log including agent's internal thoughts\n * - receivedMessageHeader: Header showing the current message being responded to\n * - focusHeader: Instruction to focus response on the received message\n */\nexport const recentMessagesProvider: Provider = {\n name: \"RECENT_MESSAGES\",\n description: \"Provides recent conversation messages with detailed context\",\n position: 94,\n\n get: async (runtime: IAgentRuntime, message: Memory, _state: State) => {\n try {\n const memoryService = runtime.getService(\n \"memory\"\n ) as MemoryService | null;\n const { roomId } = message;\n\n // Get configuration\n const config = memoryService?.getConfig() || {\n shortTermSummarizationThreshold: 16,\n shortTermRetainRecent: 6,\n };\n\n // Get conversation length setting\n const conversationLength = runtime.getConversationLength();\n\n // Determine how many messages to fetch and from where\n let messagesToFetch = config.shortTermRetainRecent;\n let startOffset = 0;\n\n // Check if we have a summary to determine offset and whether to use summarization mode\n let hasSummary = false;\n if (memoryService) {\n const currentSummary = await memoryService.getCurrentSessionSummary(\n roomId\n );\n if (currentSummary) {\n hasSummary = true;\n // When we have a summary, fetch recent messages after the summary offset\n startOffset = currentSummary.lastMessageOffset || 0;\n }\n }\n\n // If no summary exists, check if we should show all messages or just recent ones\n if (!hasSummary) {\n // Get all messages to count dialogue messages\n const allMessages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: conversationLength,\n unique: false,\n });\n\n const dialogueMessageCount = allMessages.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n ).length;\n\n // If below threshold, show all messages; otherwise show recent only\n if (dialogueMessageCount < config.shortTermSummarizationThreshold) {\n messagesToFetch = conversationLength;\n }\n }\n\n // Parallelize data fetching\n const [entitiesData, room, recentMessagesData] = await Promise.all([\n getEntityDetails({ runtime, roomId }),\n runtime.getRoom(roomId),\n runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: messagesToFetch,\n unique: false,\n start: startOffset,\n }),\n ]);\n\n // Determine format based on room type\n const isPostFormat = room?.type\n ? room.type === ChannelType.FEED || room.type === ChannelType.THREAD\n : false;\n\n // Filter to dialogue messages only (exclude action results)\n const dialogueMessages = recentMessagesData.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n );\n\n // Format recent messages\n let recentMessagesText = \"\";\n if (dialogueMessages.length > 0) {\n if (isPostFormat) {\n recentMessagesText = formatPosts({\n messages: dialogueMessages,\n entities: entitiesData,\n conversationHeader: false,\n });\n } else {\n recentMessagesText = formatMessages({\n messages: dialogueMessages,\n entities: entitiesData,\n });\n }\n\n if (recentMessagesText) {\n recentMessagesText = addHeader(\n \"# Recent Messages\",\n recentMessagesText\n );\n }\n }\n\n // Format conversation logs (simple format without IDs)\n const formatConversationLog = (\n messages: Memory[],\n includeThoughts: boolean\n ): string => {\n return messages\n .sort((a, b) => (a.createdAt || 0) - (b.createdAt || 0))\n .map((msg) => {\n const entity = entitiesData.find(\n (e: Entity) => e.id === msg.entityId\n );\n const entityName =\n entity?.names[0] ||\n (msg.entityId === runtime.agentId\n ? runtime.character.name\n : \"Unknown\");\n const timestamp = msg.createdAt\n ? new Date(msg.createdAt).toLocaleString()\n : \"Unknown time\";\n\n const text = msg.content.text || \"\";\n const thought =\n includeThoughts && msg.content.thought\n ? `\\n [Internal thought: ${msg.content.thought}]`\n : \"\";\n\n return `[${timestamp}] ${entityName}: ${text}${thought}`;\n })\n .join(\"\\n\");\n };\n\n const conversationLog = addHeader(\n \"# Conversation Messages\",\n formatConversationLog(dialogueMessages, false)\n );\n const conversationLogWithAgentThoughts = addHeader(\n \"# Conversation Messages\",\n formatConversationLog(dialogueMessages, true)\n );\n\n // Build received message header\n const metaData = message.metadata as CustomMetadata;\n const senderName =\n entitiesData.find((entity: Entity) => entity.id === message.entityId)\n ?.names[0] ||\n metaData?.entityName ||\n \"Unknown User\";\n const receivedMessageContent = message.content.text;\n const hasReceivedMessage = !!receivedMessageContent?.trim();\n\n const receivedMessageHeader = hasReceivedMessage\n ? addHeader(\n \"# Received Message\",\n `${senderName}: ${receivedMessageContent}`\n )\n : \"\";\n\n const focusHeader = hasReceivedMessage\n ? addHeader(\n \"# Focus your response\",\n `You are replying to the above message from **${senderName}**. Keep your answer relevant to that message.`\n )\n : \"\";\n\n // Combine sections for text output\n const text = [recentMessagesText, receivedMessageHeader, focusHeader]\n .filter(Boolean)\n .join(\"\\n\\n\");\n\n return {\n data: {\n messages: dialogueMessages,\n },\n values: {\n recentMessages: recentMessagesText,\n conversationLog,\n conversationLogWithAgentThoughts,\n ...(receivedMessageHeader && { receivedMessageHeader }),\n ...(focusHeader && { focusHeader }),\n },\n text,\n };\n } catch (error) {\n logger.error({ error }, \"Error in recentMessagesProvider:\");\n return {\n data: {\n messages: [],\n },\n values: {\n recentMessages: \"\",\n conversationLog: \"\",\n conversationLogWithAgentThoughts: \"\",\n receivedMessageHeader: \"\",\n focusHeader: \"\",\n },\n text: \"\",\n };\n }\n },\n};\n",
15
- "import type { Plugin } from '@elizaos/core';\nimport { MemoryService } from './services/memory-service';\nimport { summarizationEvaluator } from './evaluators/summarization';\nimport { longTermExtractionEvaluator } from './evaluators/long-term-extraction';\n// import { shortTermMemoryProvider } from './providers/short-term-memory';\nimport { longTermMemoryProvider } from './providers/long-term-memory';\nimport { contextSummaryProvider } from './providers/context-summary';\nimport { recentMessagesProvider } from './providers/recent-messages';\n// import { rememberAction } from './actions/remember';\nimport * as schema from './schemas/index';\n\nexport * from './types/index';\nexport * from './schemas/index';\nexport { MemoryService } from './services/memory-service';\nexport { contextSummaryProvider } from './providers/context-summary';\nexport { recentMessagesProvider } from './providers/recent-messages';\nexport { longTermMemoryProvider } from './providers/long-term-memory';\n\n/**\n * Memory Plugin\n *\n * Advanced memory management plugin that provides:\n *\n * **Short-term Memory (Conversation Summarization)**:\n * - Automatically summarizes long conversations to reduce context size\n * - Retains recent messages while archiving older ones as summaries\n * - Configurable thresholds for when to summarize\n *\n * **Long-term Memory (Persistent Facts)**:\n * - Extracts and stores persistent facts about users\n * - Categorizes information (identity, expertise, preferences, etc.)\n * - Provides context-aware user profiles across all conversations\n *\n * **Components**:\n * - `MemoryService`: Manages all memory operations\n * - Evaluators: Process conversations to create summaries and extract facts\n * - Providers: Inject memory context into conversations\n * - Actions: Allow manual memory storage via user commands\n *\n * **Configuration** (via environment variables):\n * - `MEMORY_SUMMARIZATION_THRESHOLD`: Messages before summarization (default: 50)\n * - `MEMORY_RETAIN_RECENT`: Recent messages to keep (default: 10)\n * - `MEMORY_LONG_TERM_ENABLED`: Enable long-term extraction (default: true)\n * - `MEMORY_CONFIDENCE_THRESHOLD`: Minimum confidence to store (default: 0.7)\n *\n * **Database Tables**:\n * - `long_term_memories`: Persistent user facts\n * - `session_summaries`: Conversation summaries\n * - `memory_access_logs`: Optional usage tracking\n */\nexport const memoryPlugin: Plugin = {\n name: 'memory',\n description:\n 'Advanced memory management with conversation summarization and long-term persistent memory',\n\n services: [MemoryService],\n\n evaluators: [summarizationEvaluator, longTermExtractionEvaluator],\n\n providers: [\n longTermMemoryProvider, \n // shortTermMemoryProvider, \n contextSummaryProvider, \n recentMessagesProvider\n ],\n\n // actions: [rememberAction],\n\n // Export schema for dynamic migrations\n schema,\n};\n\nexport default memoryPlugin;\n"
16
- ],
17
- "mappings": "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",
18
- "debugId": "38CF5E9664327F8064756E2164756E21",
19
- "names": []
20
- }
@@ -1,2 +0,0 @@
1
- export * from "./index";
2
- export { default } from "./index";
@@ -1,2 +0,0 @@
1
- export * from "./index";
2
- export { default } from "./index";
@@ -1,2 +0,0 @@
1
- export * from '../index';
2
- export { default } from '../index';
@@ -1,20 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/services/memory-service.ts", "../../src/schemas/long-term-memories.ts", "../../src/schemas/session-summaries.ts", "../../src/schemas/memory-access-logs.ts", "../../src/evaluators/summarization.ts", "../../src/evaluators/long-term-extraction.ts", "../../src/types/index.ts", "../../src/providers/long-term-memory.ts", "../../src/providers/context-summary.ts", "../../src/providers/recent-messages.ts", "../../src/index.ts"],
4
- "sourcesContent": [
5
- "import {\n type IAgentRuntime,\n Service,\n type UUID,\n logger,\n type ServiceTypeName,\n} from '@elizaos/core';\nimport { eq, and, desc, sql, cosineDistance, gte } from 'drizzle-orm';\nimport {\n type LongTermMemory,\n type SessionSummary,\n type MemoryConfig,\n LongTermMemoryCategory,\n} from '../types/index';\nimport { longTermMemories, sessionSummaries } from '../schemas/index';\n\n/**\n * Memory Service\n * Manages both short-term (session summaries) and long-term (persistent facts) memory\n */\nexport class MemoryService extends Service {\n static serviceType: ServiceTypeName = 'memory' as ServiceTypeName;\n\n private sessionMessageCounts: Map<UUID, number>;\n private memoryConfig: MemoryConfig;\n private lastExtractionCheckpoints: Map<string, number>; // Track last extraction per entity-room pair\n\n capabilityDescription =\n 'Advanced memory management with short-term summarization and long-term persistent facts';\n\n constructor(runtime?: IAgentRuntime) {\n super(runtime);\n this.sessionMessageCounts = new Map();\n this.lastExtractionCheckpoints = new Map();\n this.memoryConfig = {\n shortTermSummarizationThreshold: 16, // Start summarization at 16 messages\n shortTermRetainRecent: 6, // Show last 6 messages when summarization is active\n shortTermSummarizationInterval: 10, // Update summary every 10 new messages\n longTermExtractionEnabled: true,\n longTermVectorSearchEnabled: false,\n longTermConfidenceThreshold: 0.85, // Stricter threshold - only high-confidence extractions\n longTermExtractionThreshold: 30, // Increased from 20 - need more context before extraction\n longTermExtractionInterval: 10, // Increased from 5 - extract less frequently\n summaryModelType: 'TEXT_LARGE',\n summaryMaxTokens: 2500,\n summaryMaxNewMessages: 20, // Cap new messages in update to prevent context bloat\n };\n }\n\n static async start(runtime: IAgentRuntime): Promise<Service> {\n const service = new MemoryService(runtime);\n await service.initialize(runtime);\n return service;\n }\n\n async stop(): Promise<void> {\n // No cleanup needed for this service\n logger.info('MemoryService stopped');\n }\n\n async initialize(runtime: IAgentRuntime): Promise<void> {\n this.runtime = runtime;\n\n // Load configuration from runtime settings\n const threshold = runtime.getSetting('MEMORY_SUMMARIZATION_THRESHOLD');\n if (threshold) {\n this.memoryConfig.shortTermSummarizationThreshold = parseInt(threshold, 10);\n }\n\n const retainRecent = runtime.getSetting('MEMORY_RETAIN_RECENT');\n if (retainRecent) {\n this.memoryConfig.shortTermRetainRecent = parseInt(retainRecent, 10);\n }\n\n const summarizationInterval = runtime.getSetting('MEMORY_SUMMARIZATION_INTERVAL');\n if (summarizationInterval) {\n this.memoryConfig.shortTermSummarizationInterval = parseInt(summarizationInterval, 10);\n }\n\n const maxNewMessages = runtime.getSetting('MEMORY_MAX_NEW_MESSAGES');\n if (maxNewMessages) {\n this.memoryConfig.summaryMaxNewMessages = parseInt(maxNewMessages, 10);\n }\n\n const longTermEnabled = runtime.getSetting('MEMORY_LONG_TERM_ENABLED');\n // Only override default if explicitly set to 'false'\n if (longTermEnabled === 'false') {\n this.memoryConfig.longTermExtractionEnabled = false;\n } else if (longTermEnabled === 'true') {\n this.memoryConfig.longTermExtractionEnabled = true;\n }\n // Otherwise keep the default value (true)\n\n const confidenceThreshold = runtime.getSetting('MEMORY_CONFIDENCE_THRESHOLD');\n if (confidenceThreshold) {\n this.memoryConfig.longTermConfidenceThreshold = parseFloat(confidenceThreshold);\n }\n\n const extractionThreshold = runtime.getSetting('MEMORY_EXTRACTION_THRESHOLD');\n if (extractionThreshold) {\n this.memoryConfig.longTermExtractionThreshold = parseInt(extractionThreshold, 10);\n }\n\n const extractionInterval = runtime.getSetting('MEMORY_EXTRACTION_INTERVAL');\n if (extractionInterval) {\n this.memoryConfig.longTermExtractionInterval = parseInt(extractionInterval, 10);\n }\n\n logger.debug(\n {\n summarizationThreshold: this.memoryConfig.shortTermSummarizationThreshold,\n summarizationInterval: this.memoryConfig.shortTermSummarizationInterval,\n maxNewMessages: this.memoryConfig.summaryMaxNewMessages,\n retainRecent: this.memoryConfig.shortTermRetainRecent,\n longTermEnabled: this.memoryConfig.longTermExtractionEnabled,\n extractionThreshold: this.memoryConfig.longTermExtractionThreshold,\n extractionInterval: this.memoryConfig.longTermExtractionInterval,\n confidenceThreshold: this.memoryConfig.longTermConfidenceThreshold,\n },\n 'MemoryService initialized'\n );\n }\n\n /**\n * Get the Drizzle database instance\n */\n private getDb(): any {\n const db = (this.runtime as any).db;\n if (!db) {\n throw new Error('Database not available');\n }\n return db;\n }\n\n /**\n * Get configuration\n */\n getConfig(): MemoryConfig {\n return { ...this.memoryConfig };\n }\n\n /**\n * Update configuration\n */\n updateConfig(updates: Partial<MemoryConfig>): void {\n this.memoryConfig = { ...this.memoryConfig, ...updates };\n }\n\n /**\n * Track message count for a room\n */\n incrementMessageCount(roomId: UUID): number {\n const current = this.sessionMessageCounts.get(roomId) || 0;\n const newCount = current + 1;\n this.sessionMessageCounts.set(roomId, newCount);\n return newCount;\n }\n\n /**\n * Reset message count for a room\n */\n resetMessageCount(roomId: UUID): void {\n this.sessionMessageCounts.set(roomId, 0);\n }\n\n /**\n * Check if summarization is needed for a room\n */\n async shouldSummarize(roomId: UUID): Promise<boolean> {\n const count = await this.runtime.countMemories(roomId, false, 'messages');\n return count >= this.memoryConfig.shortTermSummarizationThreshold;\n }\n\n /**\n * Generate cache key for tracking extraction checkpoints per entity-room pair\n */\n private getExtractionKey(entityId: UUID, roomId: UUID): string {\n return `memory:extraction:${entityId}:${roomId}`;\n }\n\n /**\n * Get the last extraction checkpoint for an entity in a room\n * Uses the cache table via adapter\n */\n async getLastExtractionCheckpoint(entityId: UUID, roomId: UUID): Promise<number> {\n const key = this.getExtractionKey(entityId, roomId);\n\n // Check in-memory cache first\n const cached = this.lastExtractionCheckpoints.get(key);\n if (cached !== undefined) {\n return cached;\n }\n\n // Check database cache table via adapter\n try {\n const checkpoint = await this.runtime.getCache<number>(key);\n const messageCount = checkpoint ?? 0;\n\n // Cache it in memory for faster access\n this.lastExtractionCheckpoints.set(key, messageCount);\n\n return messageCount;\n } catch (error) {\n logger.warn({ error }, 'Failed to get extraction checkpoint from cache');\n return 0;\n }\n }\n\n /**\n * Set the last extraction checkpoint for an entity in a room\n * Uses the cache table via adapter\n */\n async setLastExtractionCheckpoint(\n entityId: UUID,\n roomId: UUID,\n messageCount: number\n ): Promise<void> {\n const key = this.getExtractionKey(entityId, roomId);\n\n // Update in-memory cache\n this.lastExtractionCheckpoints.set(key, messageCount);\n\n // Persist to database cache table via adapter\n try {\n await this.runtime.setCache(key, messageCount);\n logger.debug(\n `Set extraction checkpoint for ${entityId} in room ${roomId} at message count ${messageCount}`\n );\n } catch (error) {\n logger.error({ error }, 'Failed to persist extraction checkpoint to cache');\n }\n }\n\n /**\n * Check if long-term extraction should run based on message count and interval\n */\n async shouldRunExtraction(\n entityId: UUID,\n roomId: UUID,\n currentMessageCount: number\n ): Promise<boolean> {\n const threshold = this.memoryConfig.longTermExtractionThreshold;\n const interval = this.memoryConfig.longTermExtractionInterval;\n \n // Don't run extraction until we reach the minimum threshold\n if (currentMessageCount < threshold) {\n return false;\n }\n\n const lastCheckpoint = await this.getLastExtractionCheckpoint(entityId, roomId);\n\n // Calculate the current checkpoint (e.g., if interval=5: 20, 25, 30, 35...)\n const currentCheckpoint = Math.floor(currentMessageCount / interval) * interval;\n\n // Run if we're at or past a checkpoint and haven't processed this checkpoint yet\n const shouldRun = currentMessageCount >= threshold && currentCheckpoint > lastCheckpoint;\n\n logger.debug(\n {\n entityId,\n roomId,\n currentMessageCount,\n threshold,\n interval,\n lastCheckpoint,\n currentCheckpoint,\n shouldRun,\n },\n 'Extraction check'\n );\n\n return shouldRun;\n }\n\n /**\n * Store a long-term memory\n */\n async storeLongTermMemory(\n memory: Omit<LongTermMemory, 'id' | 'createdAt' | 'updatedAt'>\n ): Promise<LongTermMemory> {\n const db = this.getDb();\n\n const id = crypto.randomUUID() as UUID;\n const now = new Date();\n\n const newMemory: LongTermMemory = {\n id,\n createdAt: now,\n updatedAt: now,\n accessCount: 0,\n ...memory,\n };\n\n try {\n await db.insert(longTermMemories).values({\n id: newMemory.id,\n agentId: newMemory.agentId,\n entityId: newMemory.entityId,\n category: newMemory.category,\n content: newMemory.content,\n metadata: newMemory.metadata || {},\n embedding: newMemory.embedding,\n confidence: newMemory.confidence,\n source: newMemory.source,\n accessCount: newMemory.accessCount,\n createdAt: now,\n updatedAt: now,\n lastAccessedAt: newMemory.lastAccessedAt,\n });\n } catch (error) {\n logger.error({ error }, 'Failed to store long-term memory');\n throw error;\n }\n\n logger.info(`Stored long-term memory: ${newMemory.category} for entity ${newMemory.entityId}`);\n return newMemory;\n }\n\n /**\n * Retrieve long-term memories for an entity\n */\n async getLongTermMemories(\n entityId: UUID,\n category?: LongTermMemoryCategory,\n limit: number = 10\n ): Promise<LongTermMemory[]> {\n const db = this.getDb();\n\n const conditions = [\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId),\n ];\n\n if (category) {\n conditions.push(eq(longTermMemories.category, category));\n }\n\n const results = await db\n .select()\n .from(longTermMemories)\n .where(and(...conditions))\n .orderBy(desc(longTermMemories.confidence), desc(longTermMemories.updatedAt))\n .limit(limit);\n\n return results.map((row) => ({\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n entityId: row.entityId as UUID,\n category: row.category as LongTermMemoryCategory,\n content: row.content,\n metadata: row.metadata as Record<string, unknown>,\n embedding: row.embedding as number[],\n confidence: row.confidence as number,\n source: row.source as string,\n createdAt: row.createdAt,\n updatedAt: row.updatedAt,\n lastAccessedAt: row.lastAccessedAt,\n accessCount: row.accessCount as number,\n }));\n }\n\n /**\n * Update a long-term memory\n * Enforces multi-tenancy by verifying agentId and entityId\n */\n async updateLongTermMemory(\n id: UUID,\n entityId: UUID,\n updates: Partial<Omit<LongTermMemory, 'id' | 'agentId' | 'entityId' | 'createdAt'>>\n ): Promise<void> {\n const db = this.getDb();\n\n const updateData: any = {\n updatedAt: new Date(),\n };\n\n if (updates.content !== undefined) {\n updateData.content = updates.content;\n }\n\n if (updates.metadata !== undefined) {\n updateData.metadata = updates.metadata;\n }\n\n if (updates.confidence !== undefined) {\n updateData.confidence = updates.confidence;\n }\n\n if (updates.embedding !== undefined) {\n updateData.embedding = updates.embedding;\n }\n\n if (updates.lastAccessedAt !== undefined) {\n updateData.lastAccessedAt = updates.lastAccessedAt;\n }\n\n if (updates.accessCount !== undefined) {\n updateData.accessCount = updates.accessCount;\n }\n\n // Enforce multi-tenancy: only update if agentId and entityId match\n await db\n .update(longTermMemories)\n .set(updateData)\n .where(\n and(\n eq(longTermMemories.id, id),\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId)\n )\n );\n\n logger.info(`Updated long-term memory: ${id} for entity ${entityId}`);\n }\n\n /**\n * Delete a long-term memory\n * Enforces multi-tenancy by verifying agentId and entityId\n */\n async deleteLongTermMemory(id: UUID, entityId: UUID): Promise<void> {\n const db = this.getDb();\n\n // Enforce multi-tenancy: only delete if agentId and entityId match\n await db\n .delete(longTermMemories)\n .where(\n and(\n eq(longTermMemories.id, id),\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId)\n )\n );\n\n logger.info(`Deleted long-term memory: ${id} for entity ${entityId}`);\n }\n\n /**\n * Get the current session summary for a room (latest one)\n */\n async getCurrentSessionSummary(roomId: UUID): Promise<SessionSummary | null> {\n const db = this.getDb();\n\n const results = await db\n .select()\n .from(sessionSummaries)\n .where(\n and(eq(sessionSummaries.agentId, this.runtime.agentId), eq(sessionSummaries.roomId, roomId))\n )\n .orderBy(desc(sessionSummaries.updatedAt))\n .limit(1);\n\n if (results.length === 0) {\n return null;\n }\n\n const row = results[0];\n return {\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n roomId: row.roomId as UUID,\n entityId: row.entityId as UUID | undefined,\n summary: row.summary,\n messageCount: row.messageCount,\n lastMessageOffset: row.lastMessageOffset,\n startTime: row.startTime,\n endTime: row.endTime,\n topics: (row.topics as string[]) || [],\n metadata: row.metadata as Record<string, unknown>,\n embedding: row.embedding as number[],\n createdAt: row.createdAt,\n updatedAt: row.updatedAt,\n };\n }\n\n /**\n * Store a session summary (initial creation)\n */\n async storeSessionSummary(\n summary: Omit<SessionSummary, 'id' | 'createdAt' | 'updatedAt'>\n ): Promise<SessionSummary> {\n const db = this.getDb();\n\n const id = crypto.randomUUID() as UUID;\n const now = new Date();\n\n const newSummary: SessionSummary = {\n id,\n createdAt: now,\n updatedAt: now,\n ...summary,\n };\n\n await db.insert(sessionSummaries).values({\n id: newSummary.id,\n agentId: newSummary.agentId,\n roomId: newSummary.roomId,\n entityId: newSummary.entityId || null,\n summary: newSummary.summary,\n messageCount: newSummary.messageCount,\n lastMessageOffset: newSummary.lastMessageOffset,\n startTime: newSummary.startTime,\n endTime: newSummary.endTime,\n topics: newSummary.topics || [],\n metadata: newSummary.metadata || {},\n embedding: newSummary.embedding,\n createdAt: now,\n updatedAt: now,\n });\n\n logger.info(`Stored session summary for room ${newSummary.roomId}`);\n return newSummary;\n }\n\n /**\n * Update an existing session summary\n * Enforces multi-tenancy by verifying agentId\n */\n async updateSessionSummary(\n id: UUID,\n roomId: UUID,\n updates: Partial<Omit<SessionSummary, 'id' | 'agentId' | 'roomId' | 'createdAt' | 'updatedAt'>>\n ): Promise<void> {\n const db = this.getDb();\n\n const updateData: any = {\n updatedAt: new Date(),\n };\n\n if (updates.summary !== undefined) {\n updateData.summary = updates.summary;\n }\n\n if (updates.messageCount !== undefined) {\n updateData.messageCount = updates.messageCount;\n }\n\n if (updates.lastMessageOffset !== undefined) {\n updateData.lastMessageOffset = updates.lastMessageOffset;\n }\n\n if (updates.endTime !== undefined) {\n updateData.endTime = updates.endTime;\n }\n\n if (updates.topics !== undefined) {\n updateData.topics = updates.topics;\n }\n\n if (updates.metadata !== undefined) {\n updateData.metadata = updates.metadata;\n }\n\n if (updates.embedding !== undefined) {\n updateData.embedding = updates.embedding;\n }\n\n // Enforce multi-tenancy: only update if agentId and roomId match\n await db\n .update(sessionSummaries)\n .set(updateData)\n .where(\n and(\n eq(sessionSummaries.id, id),\n eq(sessionSummaries.agentId, this.runtime.agentId),\n eq(sessionSummaries.roomId, roomId)\n )\n );\n\n logger.info(`Updated session summary: ${id} for room ${roomId}`);\n }\n\n /**\n * Get session summaries for a room\n */\n async getSessionSummaries(roomId: UUID, limit: number = 5): Promise<SessionSummary[]> {\n const db = this.getDb();\n\n const results = await db\n .select()\n .from(sessionSummaries)\n .where(\n and(eq(sessionSummaries.agentId, this.runtime.agentId), eq(sessionSummaries.roomId, roomId))\n )\n .orderBy(desc(sessionSummaries.updatedAt))\n .limit(limit);\n\n return results.map((row) => ({\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n roomId: row.roomId as UUID,\n entityId: row.entityId as UUID | undefined,\n summary: row.summary,\n messageCount: row.messageCount,\n lastMessageOffset: row.lastMessageOffset,\n startTime: row.startTime,\n endTime: row.endTime,\n topics: (row.topics as string[]) || [],\n metadata: row.metadata as Record<string, unknown>,\n embedding: row.embedding as number[],\n createdAt: row.createdAt,\n updatedAt: row.updatedAt,\n }));\n }\n\n /**\n * Search long-term memories by semantic similarity (if embeddings are available)\n */\n async searchLongTermMemories(\n entityId: UUID,\n queryEmbedding: number[],\n limit: number = 5,\n matchThreshold: number = 0.7\n ): Promise<LongTermMemory[]> {\n if (!this.memoryConfig.longTermVectorSearchEnabled) {\n logger.warn('Vector search is not enabled, falling back to recent memories');\n return this.getLongTermMemories(entityId, undefined, limit);\n }\n\n const db = this.getDb();\n\n try {\n // Clean the vector to ensure all numbers are finite and properly formatted\n const cleanVector = queryEmbedding.map((n) =>\n Number.isFinite(n) ? Number(n.toFixed(6)) : 0\n );\n\n // Calculate similarity using Drizzle's cosineDistance\n const similarity = sql<number>`1 - (${cosineDistance(\n longTermMemories.embedding,\n cleanVector\n )})`;\n\n const conditions = [\n eq(longTermMemories.agentId, this.runtime.agentId),\n eq(longTermMemories.entityId, entityId),\n sql`${longTermMemories.embedding} IS NOT NULL`,\n ];\n\n // Add similarity threshold if specified\n if (matchThreshold > 0) {\n conditions.push(gte(similarity, matchThreshold));\n }\n\n const results = await db\n .select({\n memory: longTermMemories,\n similarity,\n })\n .from(longTermMemories)\n .where(and(...conditions))\n .orderBy(desc(similarity))\n .limit(limit);\n\n return results.map((row) => ({\n id: row.memory.id as UUID,\n agentId: row.memory.agentId as UUID,\n entityId: row.memory.entityId as UUID,\n category: row.memory.category as LongTermMemoryCategory,\n content: row.memory.content,\n metadata: row.memory.metadata as Record<string, unknown>,\n embedding: row.memory.embedding as number[],\n confidence: row.memory.confidence as number,\n source: row.memory.source as string,\n createdAt: row.memory.createdAt,\n updatedAt: row.memory.updatedAt,\n lastAccessedAt: row.memory.lastAccessedAt,\n accessCount: row.memory.accessCount as number,\n similarity: row.similarity,\n }));\n } catch (error) {\n logger.warn({ error }, 'Vector search failed, falling back to recent memories');\n return this.getLongTermMemories(entityId, undefined, limit);\n }\n }\n\n /**\n * Get all long-term memories formatted for context\n */\n async getFormattedLongTermMemories(entityId: UUID): Promise<string> {\n const memories = await this.getLongTermMemories(entityId, undefined, 20);\n\n if (memories.length === 0) {\n return '';\n }\n\n // Group by category\n const grouped = new Map<LongTermMemoryCategory, LongTermMemory[]>();\n\n for (const memory of memories) {\n if (!grouped.has(memory.category)) {\n grouped.set(memory.category, []);\n }\n grouped.get(memory.category)?.push(memory);\n }\n\n // Format each category\n const sections: string[] = [];\n\n for (const [category, categoryMemories] of grouped.entries()) {\n const categoryName = category\n .split('_')\n .map((word) => word.charAt(0).toUpperCase() + word.slice(1))\n .join(' ');\n\n const items = categoryMemories.map((m) => `- ${m.content}`).join('\\n');\n sections.push(`**${categoryName}**:\\n${items}`);\n }\n\n return sections.join('\\n\\n');\n }\n}\n",
6
- "import { sql } from 'drizzle-orm';\nimport {\n pgTable,\n text,\n integer,\n jsonb,\n real,\n index,\n varchar,\n timestamp,\n} from 'drizzle-orm/pg-core';\n\n/**\n * Long-term memory storage table\n * Stores persistent facts about users across all conversations\n */\nexport const longTermMemories = pgTable(\n 'long_term_memories',\n {\n id: varchar('id', { length: 36 }).primaryKey(),\n agentId: varchar('agent_id', { length: 36 }).notNull(),\n entityId: varchar('entity_id', { length: 36 }).notNull(),\n category: text('category').notNull(),\n content: text('content').notNull(),\n metadata: jsonb('metadata'),\n embedding: real('embedding').array(),\n confidence: real('confidence').default(1.0),\n source: text('source'),\n createdAt: timestamp('created_at')\n .default(sql`now()`)\n .notNull(),\n updatedAt: timestamp('updated_at')\n .default(sql`now()`)\n .notNull(),\n lastAccessedAt: timestamp('last_accessed_at'),\n accessCount: integer('access_count').default(0),\n },\n (table) => ({\n agentEntityIdx: index('long_term_memories_agent_entity_idx').on(table.agentId, table.entityId),\n categoryIdx: index('long_term_memories_category_idx').on(table.category),\n confidenceIdx: index('long_term_memories_confidence_idx').on(table.confidence),\n createdAtIdx: index('long_term_memories_created_at_idx').on(table.createdAt),\n })\n);\n",
7
- "import { sql } from 'drizzle-orm';\nimport {\n pgTable,\n text,\n integer,\n jsonb,\n real,\n index,\n varchar,\n timestamp,\n} from 'drizzle-orm/pg-core';\n\n/**\n * Session summaries table\n * Stores condensed summaries of conversation sessions\n */\nexport const sessionSummaries = pgTable(\n 'session_summaries',\n {\n id: varchar('id', { length: 36 }).primaryKey(),\n agentId: varchar('agent_id', { length: 36 }).notNull(),\n roomId: varchar('room_id', { length: 36 }).notNull(),\n entityId: varchar('entity_id', { length: 36 }),\n summary: text('summary').notNull(),\n messageCount: integer('message_count').notNull(),\n lastMessageOffset: integer('last_message_offset').notNull().default(0),\n startTime: timestamp('start_time').notNull(),\n endTime: timestamp('end_time').notNull(),\n topics: jsonb('topics'),\n metadata: jsonb('metadata'),\n embedding: real('embedding').array(),\n createdAt: timestamp('created_at')\n .default(sql`now()`)\n .notNull(),\n updatedAt: timestamp('updated_at')\n .default(sql`now()`)\n .notNull(),\n },\n (table) => ({\n agentRoomIdx: index('session_summaries_agent_room_idx').on(table.agentId, table.roomId),\n entityIdx: index('session_summaries_entity_idx').on(table.entityId),\n startTimeIdx: index('session_summaries_start_time_idx').on(table.startTime),\n })\n);\n",
8
- "import { sql } from 'drizzle-orm';\nimport { pgTable, text, integer, real, index, varchar, timestamp } from 'drizzle-orm/pg-core';\n\n/**\n * Memory access logs (optional - for tracking and improving memory retrieval)\n */\nexport const memoryAccessLogs = pgTable(\n 'memory_access_logs',\n {\n id: varchar('id', { length: 36 }).primaryKey(),\n agentId: varchar('agent_id', { length: 36 }).notNull(),\n memoryId: varchar('memory_id', { length: 36 }).notNull(),\n memoryType: text('memory_type').notNull(), // 'long_term' or 'session_summary'\n accessedAt: timestamp('accessed_at')\n .default(sql`now()`)\n .notNull(),\n roomId: varchar('room_id', { length: 36 }),\n relevanceScore: real('relevance_score'),\n wasUseful: integer('was_useful'), // 1 = useful, 0 = not useful, null = unknown\n },\n (table) => ({\n memoryIdx: index('memory_access_logs_memory_idx').on(table.memoryId),\n agentIdx: index('memory_access_logs_agent_idx').on(table.agentId),\n accessedAtIdx: index('memory_access_logs_accessed_at_idx').on(table.accessedAt),\n })\n);\n",
9
- "import {\n type IAgentRuntime,\n type Memory,\n type Evaluator,\n logger,\n ModelType,\n composePromptFromState,\n type UUID,\n} from \"@elizaos/core\";\nimport { MemoryService } from \"../services/memory-service\";\nimport type { SummaryResult } from \"../types/index\";\n\n/**\n * Helper function to get dialogue messages count (excluding action results)\n * This matches the filtering logic in short-term-memory provider\n */\nasync function getDialogueMessageCount(\n runtime: IAgentRuntime,\n roomId: UUID\n): Promise<number> {\n // We need to fetch messages to filter them properly\n // Fetch a reasonable batch to check\n const messages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: 100, // Check last 100 messages\n unique: false,\n });\n\n const dialogueMessages = messages.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n );\n\n return dialogueMessages.length;\n}\n\n/**\n * Template for generating initial conversation summary\n */\nconst initialSummarizationTemplate = `# Task: Summarize Conversation\n\nYou are analyzing a conversation to create a concise summary that captures the key points, topics, and important details.\n\n# Recent Messages\n{{recentMessages}}\n\n# Instructions\nGenerate a summary that:\n1. Captures the main topics discussed\n2. Highlights key information shared\n3. Notes any decisions made or questions asked\n4. Maintains context for future reference\n5. Is concise but comprehensive\n\n**IMPORTANT**: Keep the summary under 2500 tokens. Be comprehensive but concise.\n\nAlso extract:\n- **Topics**: List of main topics discussed (comma-separated)\n- **Key Points**: Important facts or decisions (bullet points)\n\nRespond in this XML format:\n<summary>\n <text>Your comprehensive summary here</text>\n <topics>topic1, topic2, topic3</topics>\n <keyPoints>\n <point>First key point</point>\n <point>Second key point</point>\n </keyPoints>\n</summary>`;\n\n/**\n * Template for updating/condensing an existing summary\n */\nconst updateSummarizationTemplate = `# Task: Update and Condense Conversation Summary\n\nYou are updating an existing conversation summary with new messages, while keeping the total summary concise.\n\n# Existing Summary\n{{existingSummary}}\n\n# Existing Topics\n{{existingTopics}}\n\n# New Messages Since Last Summary\n{{newMessages}}\n\n# Instructions\nUpdate the summary by:\n1. Merging the existing summary with insights from the new messages\n2. Removing redundant or less important details to stay under the token limit\n3. Keeping the most important context and decisions\n4. Adding new topics if they emerge\n5. **CRITICAL**: Keep the ENTIRE updated summary under 2500 tokens\n\nThe goal is a rolling summary that captures the essence of the conversation without growing indefinitely.\n\nRespond in this XML format:\n<summary>\n <text>Your updated and condensed summary here</text>\n <topics>topic1, topic2, topic3</topics>\n <keyPoints>\n <point>First key point</point>\n <point>Second key point</point>\n </keyPoints>\n</summary>`;\n\n/**\n * Parse XML summary response\n */\nfunction parseSummaryXML(xml: string): SummaryResult {\n const summaryMatch = xml.match(/<text>([\\s\\S]*?)<\\/text>/);\n const topicsMatch = xml.match(/<topics>([\\s\\S]*?)<\\/topics>/);\n const keyPointsMatches = xml.matchAll(/<point>([\\s\\S]*?)<\\/point>/g);\n\n const summary = summaryMatch\n ? summaryMatch[1].trim()\n : \"Summary not available\";\n const topics = topicsMatch\n ? topicsMatch[1]\n .split(\",\")\n .map((t) => t.trim())\n .filter(Boolean)\n : [];\n const keyPoints = Array.from(keyPointsMatches).map((match) =>\n match[1].trim()\n );\n\n return { summary, topics, keyPoints };\n}\n\n/**\n * Short-term Memory Summarization Evaluator\n *\n * Automatically generates and updates conversation summaries when conversations\n * exceed the configured threshold (default: 16 messages).\n *\n * BEHAVIOR:\n * - Monitors message count per room\n * - Creates initial summary when count >= threshold (e.g., 16 messages)\n * - Updates summary at regular intervals (e.g., every 10 new messages)\n * - Condenses existing summary with new messages to stay under token limit\n * - Tracks offset to avoid re-processing messages\n * - Caps new messages per update to prevent context bloat (default: 20)\n *\n * OPTIMIZATION:\n * - Only triggers LLM when crossing threshold or interval boundaries\n * - Processes only NEW messages since last update\n * - Maintains rolling summary (fixed size, not ever-growing)\n * - LLM is instructed to merge and condense, keeping under 2500 tokens\n *\n * INTEGRATION:\n * Works with shortTermMemoryProvider which:\n * - Shows full conversation when < threshold (no summarization needed)\n * - Shows summaries + recent messages when >= threshold (optimized context)\n *\n * This creates an adaptive system that starts with full context and seamlessly\n * transitions to efficient summarization as conversations grow.\n */\nexport const summarizationEvaluator: Evaluator = {\n name: \"MEMORY_SUMMARIZATION\",\n description:\n \"Automatically summarizes conversations to optimize context usage\",\n similes: [\n \"CONVERSATION_SUMMARY\",\n \"CONTEXT_COMPRESSION\",\n \"MEMORY_OPTIMIZATION\",\n ],\n alwaysRun: true,\n\n validate: async (\n runtime: IAgentRuntime,\n message: Memory\n ): Promise<boolean> => {\n // Only run after actual messages (not during generation or on empty messages)\n if (!message.content?.text) {\n return false;\n }\n\n const memoryService = runtime.getService(\"memory\") as MemoryService | null;\n if (!memoryService) {\n return false;\n }\n\n const config = memoryService.getConfig();\n\n // Get dialogue message count (excluding action results)\n const currentDialogueCount = await getDialogueMessageCount(\n runtime,\n message.roomId\n );\n\n // Get existing summary to check if we need initial or update\n const existingSummary = await memoryService.getCurrentSessionSummary(\n message.roomId\n );\n\n if (!existingSummary) {\n // No summary yet - create initial summary when dialogue threshold is reached\n const shouldSummarize =\n currentDialogueCount >= config.shortTermSummarizationThreshold;\n return shouldSummarize;\n } else {\n // Summary exists - check if we have enough new dialogue messages since last update\n const newDialogueCount =\n currentDialogueCount - existingSummary.lastMessageOffset;\n const shouldUpdate =\n newDialogueCount >= config.shortTermSummarizationInterval;\n return shouldUpdate;\n }\n },\n\n handler: async (runtime: IAgentRuntime, message: Memory): Promise<void> => {\n const memoryService = runtime.getService(\"memory\") as MemoryService;\n if (!memoryService) {\n logger.error(\"MemoryService not found\");\n return;\n }\n\n const config = memoryService.getConfig();\n const { roomId } = message;\n\n try {\n logger.info(`Starting summarization for room ${roomId}`);\n\n // Get the current summary (if any)\n const existingSummary = await memoryService.getCurrentSessionSummary(\n roomId\n );\n const lastOffset = existingSummary?.lastMessageOffset || 0;\n\n // Get all messages and filter to dialogue only\n const allMessages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: 1000, // Get a large batch to ensure we have all relevant messages\n unique: false,\n });\n\n // Filter to dialogue messages only (matching provider logic)\n const allDialogueMessages = allMessages.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n );\n\n // Get total dialogue message count\n const totalDialogueCount = allDialogueMessages.length;\n\n // Calculate how many new dialogue messages we have since last summary\n const newDialogueCount = totalDialogueCount - lastOffset;\n\n if (newDialogueCount === 0) {\n logger.debug(\"No new dialogue messages to summarize\");\n return;\n }\n\n // Cap the number of new messages to prevent context bloat\n const maxNewMessages = config.summaryMaxNewMessages || 50;\n const messagesToProcess = Math.min(newDialogueCount, maxNewMessages);\n\n // Log if we're hitting the cap\n if (newDialogueCount > maxNewMessages) {\n logger.warn(\n `Capping new dialogue messages at ${maxNewMessages} (${newDialogueCount} available). Oldest messages will be skipped.`\n );\n }\n\n // Sort all dialogue messages by timestamp\n const sortedDialogueMessages = allDialogueMessages.sort(\n (a, b) => (a.createdAt || 0) - (b.createdAt || 0)\n );\n\n // Get new dialogue messages since last offset\n const newDialogueMessages = sortedDialogueMessages.slice(\n lastOffset,\n lastOffset + messagesToProcess\n );\n\n if (newDialogueMessages.length === 0) {\n logger.debug(\"No new dialogue messages retrieved after filtering\");\n return;\n }\n\n // Format messages for summarization\n const formattedMessages = newDialogueMessages\n .map((msg) => {\n const sender =\n msg.entityId === runtime.agentId ? runtime.character.name : \"User\";\n return `${sender}: ${msg.content.text || \"[non-text message]\"}`;\n })\n .join(\"\\n\");\n\n // Generate or update summary using LLM\n const state = await runtime.composeState(message);\n let prompt: string;\n let template: string;\n\n if (existingSummary) {\n // Update existing summary\n template = updateSummarizationTemplate;\n prompt = composePromptFromState({\n state: {\n ...state,\n existingSummary: existingSummary.summary,\n existingTopics: existingSummary.topics?.join(\", \") || \"None\",\n newMessages: formattedMessages,\n },\n template,\n });\n } else {\n // Create initial summary - use ALL dialogue messages for comprehensive initial summary\n const initialMessages = sortedDialogueMessages\n .map((msg) => {\n const sender =\n msg.entityId === runtime.agentId\n ? runtime.character.name\n : \"User\";\n return `${sender}: ${msg.content.text || \"[non-text message]\"}`;\n })\n .join(\"\\n\");\n\n template = initialSummarizationTemplate;\n prompt = composePromptFromState({\n state: {\n ...state,\n recentMessages: initialMessages,\n },\n template,\n });\n }\n\n const response = await runtime.useModel(ModelType.TEXT_LARGE, {\n prompt,\n maxTokens: config.summaryMaxTokens || 2500,\n });\n\n const summaryResult = parseSummaryXML(response);\n\n logger.info(\n `${\n existingSummary ? \"Updated\" : \"Generated\"\n } summary: ${summaryResult.summary.substring(0, 100)}...`\n );\n\n // Calculate new offset based on dialogue messages processed\n const newOffset = lastOffset + newDialogueMessages.length;\n\n // Get timing info\n const firstMessage = newDialogueMessages[0];\n const lastMessage = newDialogueMessages[newDialogueMessages.length - 1];\n\n const startTime = existingSummary\n ? existingSummary.startTime\n : firstMessage?.createdAt && firstMessage.createdAt > 0\n ? new Date(firstMessage.createdAt)\n : new Date();\n const endTime =\n lastMessage?.createdAt && lastMessage.createdAt > 0\n ? new Date(lastMessage.createdAt)\n : new Date();\n\n if (existingSummary) {\n // Update existing summary\n await memoryService.updateSessionSummary(existingSummary.id, roomId, {\n summary: summaryResult.summary,\n messageCount:\n existingSummary.messageCount + newDialogueMessages.length,\n lastMessageOffset: newOffset,\n endTime,\n topics: summaryResult.topics,\n metadata: {\n keyPoints: summaryResult.keyPoints,\n },\n });\n\n logger.info(\n `Updated summary for room ${roomId}: ${newDialogueMessages.length} new dialogue messages processed (offset: ${lastOffset} → ${newOffset})`\n );\n } else {\n // Create new summary - offset is total dialogue count\n await memoryService.storeSessionSummary({\n agentId: runtime.agentId,\n roomId,\n entityId:\n message.entityId !== runtime.agentId ? message.entityId : undefined,\n summary: summaryResult.summary,\n messageCount: totalDialogueCount,\n lastMessageOffset: totalDialogueCount,\n startTime,\n endTime,\n topics: summaryResult.topics,\n metadata: {\n keyPoints: summaryResult.keyPoints,\n },\n });\n\n logger.info(\n `Created new summary for room ${roomId}: ${totalDialogueCount} dialogue messages summarized (offset: 0 → ${totalDialogueCount})`\n );\n }\n\n // Note: We do NOT delete messages - they stay in the database\n // The offset tracks what dialogue messages have been summarized\n } catch (error) {\n logger.error({ error }, \"Error during summarization:\");\n }\n },\n\n examples: [],\n};\n",
10
- "import {\n type IAgentRuntime,\n type Memory,\n type Evaluator,\n logger,\n ModelType,\n composePromptFromState,\n} from \"@elizaos/core\";\nimport { MemoryService } from \"../services/memory-service\";\nimport { LongTermMemoryCategory, type MemoryExtraction } from \"../types/index\";\n\n/**\n * Template for extracting long-term memories using cognitive science memory types\n */\nconst extractionTemplate = `# Task: Extract Long-Term Memory (Strict Criteria)\n\nYou are analyzing a conversation to extract ONLY the most critical, persistent information about the user using cognitive science memory categories.\n\n# Recent Messages\n{{recentMessages}}\n\n# Current Long-Term Memories\n{{existingMemories}}\n\n# Memory Categories (Based on Cognitive Science)\n\n## 1. EPISODIC Memory\nPersonal experiences and specific events with temporal/spatial context.\n**Examples:**\n- \"User completed migration project from MongoDB to PostgreSQL in Q2 2024\"\n- \"User encountered authentication bug in production on March 15th\"\n- \"User had a negative experience with Docker networking in previous job\"\n\n**Requirements:**\n- Must include WHO did WHAT, WHEN/WHERE\n- Must be a specific, concrete event (not a pattern)\n- Must have significant impact or relevance to future work\n\n## 2. SEMANTIC Memory\nGeneral facts, concepts, knowledge, and established truths about the user.\n**Examples:**\n- \"User is a senior backend engineer with 8 years experience\"\n- \"User specializes in distributed systems and microservices architecture\"\n- \"User's primary programming language is TypeScript\"\n- \"User works at Acme Corp as technical lead\"\n\n**Requirements:**\n- Must be factual, timeless information\n- Must be explicitly stated or demonstrated conclusively\n- No speculation or inference from single instances\n- Core identity, expertise, or knowledge only\n\n## 3. PROCEDURAL Memory\nSkills, workflows, methodologies, and how-to knowledge.\n**Examples:**\n- \"User follows strict TDD workflow: write tests first, then implementation\"\n- \"User prefers git rebase over merge to maintain linear history\"\n- \"User's debugging process: check logs → reproduce locally → binary search\"\n- \"User always writes JSDoc comments before implementing functions\"\n\n**Requirements:**\n- Must describe HOW user does something\n- Must be a repeated, consistent pattern (seen 3+ times or explicitly stated as standard practice)\n- Must be a workflow, methodology, or skill application\n- Not one-off preferences\n\n# ULTRA-STRICT EXTRACTION CRITERIA\n\n## ✅ DO EXTRACT (Only These):\n\n**EPISODIC:**\n- Significant completed projects or milestones\n- Important bugs, incidents, or problems encountered\n- Major decisions made with lasting impact\n- Formative experiences that shape future work\n\n**SEMANTIC:**\n- Professional identity (role, title, company)\n- Core expertise and specializations (stated explicitly or demonstrated conclusively)\n- Primary languages, frameworks, or tools (not exploratory use)\n- Established facts about their work context\n\n**PROCEDURAL:**\n- Consistent workflows demonstrated 3+ times or explicitly stated\n- Standard practices user always follows\n- Methodology preferences with clear rationale\n- Debugging, testing, or development processes\n\n## ❌ NEVER EXTRACT:\n\n- **One-time requests or tasks** (e.g., \"can you generate an image\", \"help me debug this\")\n- **Casual conversations** without lasting significance\n- **Exploratory questions** (e.g., \"how does X work?\")\n- **Temporary context** (current bug, today's task)\n- **Preferences from single occurrence** (e.g., user asked for code once)\n- **Social pleasantries** (thank you, greetings)\n- **Testing or experimentation** (trying out a feature)\n- **Common patterns everyone has** (likes clear explanations)\n- **Situational information** (working on feature X today)\n- **Opinions without persistence** (single complaint, isolated praise)\n- **General knowledge** (not specific to user)\n\n# Quality Gates (ALL Must Pass)\n\n1. **Significance Test**: Will this matter in 3+ months?\n2. **Specificity Test**: Is this concrete and actionable?\n3. **Evidence Test**: Is there strong evidence (3+ instances OR explicit self-identification)?\n4. **Uniqueness Test**: Is this specific to THIS user (not generic)?\n5. **Confidence Test**: Confidence must be >= 0.85 (be VERY conservative)\n6. **Non-Redundancy Test**: Does this add NEW information not in existing memories?\n\n# Confidence Scoring (Be Conservative)\n\n- **0.95-1.0**: User explicitly stated as core identity/practice AND demonstrated multiple times\n- **0.85-0.94**: User explicitly stated OR consistently demonstrated 5+ times\n- **0.75-0.84**: Strong pattern (3-4 instances) with supporting context\n- **Below 0.75**: DO NOT EXTRACT (insufficient evidence)\n\n# Critical Instructions\n\n1. **Default to NOT extracting** - When in doubt, skip it\n2. **Require overwhelming evidence** - One or two mentions is NOT enough\n3. **Focus on what's PERSISTENT** - Not what's temporary or situational\n4. **Verify against existing memories** - Don't duplicate or contradict\n5. **Maximum 2-3 extractions per run** - Quality over quantity\n\n**If there are no qualifying facts (which is common), respond with <memories></memories>**\n\n# Response Format\n\n<memories>\n <memory>\n <category>semantic</category>\n <content>User is a senior TypeScript developer with 8 years of backend experience</content>\n <confidence>0.95</confidence>\n </memory>\n <memory>\n <category>procedural</category>\n <content>User follows TDD workflow: writes tests before implementation, runs tests after each change</content>\n <confidence>0.88</confidence>\n </memory>\n <memory>\n <category>episodic</category>\n <content>User led database migration from MongoDB to PostgreSQL for payment system in Q2 2024</content>\n <confidence>0.92</confidence>\n </memory>\n</memories>`;\n\n/**\n * Parse XML memory extraction response\n */\nfunction parseMemoryExtractionXML(xml: string): MemoryExtraction[] {\n const memoryMatches = xml.matchAll(\n /<memory>[\\s\\S]*?<category>(.*?)<\\/category>[\\s\\S]*?<content>(.*?)<\\/content>[\\s\\S]*?<confidence>(.*?)<\\/confidence>[\\s\\S]*?<\\/memory>/g\n );\n\n const extractions: MemoryExtraction[] = [];\n\n for (const match of memoryMatches) {\n const category = match[1].trim() as LongTermMemoryCategory;\n const content = match[2].trim();\n const confidence = parseFloat(match[3].trim());\n\n // Validate category\n if (!Object.values(LongTermMemoryCategory).includes(category)) {\n logger.warn(`Invalid memory category: ${category}`);\n continue;\n }\n\n if (content && !isNaN(confidence)) {\n extractions.push({ category, content, confidence });\n }\n }\n\n return extractions;\n}\n\n/**\n * Long-term Memory Extraction Evaluator\n *\n * Analyzes conversations to extract persistent facts about users that should be remembered\n * across all future conversations.\n */\nexport const longTermExtractionEvaluator: Evaluator = {\n name: \"LONG_TERM_MEMORY_EXTRACTION\",\n description: \"Extracts long-term facts about users from conversations\",\n similes: [\"MEMORY_EXTRACTION\", \"FACT_LEARNING\", \"USER_PROFILING\"],\n alwaysRun: true,\n\n validate: async (\n runtime: IAgentRuntime,\n message: Memory\n ): Promise<boolean> => {\n // Only run on user messages (not agent's own)\n if (message.entityId === runtime.agentId) {\n return false;\n }\n\n if (!message.content?.text) {\n return false;\n }\n\n const memoryService = runtime.getService(\"memory\") as MemoryService | null;\n if (!memoryService) {\n return false;\n }\n\n const config = memoryService.getConfig();\n if (!config.longTermExtractionEnabled) {\n logger.debug(\"Long-term memory extraction is disabled\");\n return false;\n }\n\n // Count total messages from this entity in this room\n const currentMessageCount = await runtime.countMemories(\n message.roomId,\n false,\n \"messages\"\n );\n\n const shouldRun = await memoryService.shouldRunExtraction(\n message.entityId,\n message.roomId,\n currentMessageCount\n );\n return shouldRun;\n },\n\n handler: async (runtime: IAgentRuntime, message: Memory): Promise<void> => {\n const memoryService = runtime.getService(\"memory\") as MemoryService;\n if (!memoryService) {\n logger.error(\"MemoryService not found\");\n return;\n }\n\n const config = memoryService.getConfig();\n const { entityId, roomId } = message;\n\n try {\n logger.info(`Extracting long-term memories for entity ${entityId}`);\n\n // Get recent conversation context\n const recentMessages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: 20,\n unique: false,\n });\n\n const formattedMessages = recentMessages\n .sort((a, b) => (a.createdAt || 0) - (b.createdAt || 0))\n .map((msg) => {\n const sender =\n msg.entityId === runtime.agentId ? runtime.character.name : \"User\";\n return `${sender}: ${msg.content.text || \"[non-text message]\"}`;\n })\n .join(\"\\n\");\n\n // Get existing long-term memories\n const existingMemories = await memoryService.getLongTermMemories(\n entityId,\n undefined,\n 30\n );\n const formattedExisting =\n existingMemories.length > 0\n ? existingMemories\n .map(\n (m) =>\n `[${m.category}] ${m.content} (confidence: ${m.confidence})`\n )\n .join(\"\\n\")\n : \"None yet\";\n\n // Generate extraction using LLM\n const state = await runtime.composeState(message);\n const prompt = composePromptFromState({\n state: {\n ...state,\n recentMessages: formattedMessages,\n existingMemories: formattedExisting,\n },\n template: extractionTemplate,\n });\n\n const response = await runtime.useModel(ModelType.TEXT_LARGE, {\n prompt,\n });\n\n const extractions = parseMemoryExtractionXML(response);\n\n logger.info(`Extracted ${extractions.length} long-term memories`);\n\n // Store each extracted memory\n for (const extraction of extractions) {\n // Apply stricter confidence threshold (0.85 minimum)\n if (\n extraction.confidence >=\n Math.max(config.longTermConfidenceThreshold, 0.85)\n ) {\n await memoryService.storeLongTermMemory({\n agentId: runtime.agentId,\n entityId,\n category: extraction.category,\n content: extraction.content,\n confidence: extraction.confidence,\n source: \"conversation\",\n metadata: {\n roomId,\n extractedAt: new Date().toISOString(),\n },\n });\n\n logger.info(\n `Stored long-term memory: [${\n extraction.category\n }] ${extraction.content.substring(0, 50)}...`\n );\n } else {\n logger.debug(\n `Skipped low-confidence memory: ${\n extraction.content\n } (confidence: ${extraction.confidence}, threshold: ${Math.max(\n config.longTermConfidenceThreshold,\n 0.85\n )})`\n );\n }\n }\n\n // Update the extraction checkpoint after successful extraction\n const currentMessageCount = await runtime.countMemories(\n roomId,\n false,\n \"messages\"\n );\n await memoryService.setLastExtractionCheckpoint(\n entityId,\n roomId,\n currentMessageCount\n );\n logger.debug(\n `Updated extraction checkpoint to ${currentMessageCount} for entity ${entityId} in room ${roomId}`\n );\n } catch (error) {\n logger.error({ error }, \"Error during long-term memory extraction:\");\n }\n },\n\n examples: [],\n};\n",
11
- "import type { UUID } from '@elizaos/core';\n\n/**\n * Categories of long-term memory based on cognitive science\n * \n * Following the widely accepted classification of human long-term memory:\n * - EPISODIC: Personal experiences and events (what happened, when, where)\n * - SEMANTIC: Facts, concepts, and knowledge (what things mean)\n * - PROCEDURAL: Skills and how-to knowledge (how to do things)\n */\nexport enum LongTermMemoryCategory {\n EPISODIC = 'episodic', // Specific events, experiences, and interactions (e.g., \"User worked on bug #123 last Tuesday\")\n SEMANTIC = 'semantic', // General facts, concepts, and knowledge (e.g., \"User is a Python developer\", \"User prefers async/await\")\n PROCEDURAL = 'procedural', // Skills, workflows, and how-to knowledge (e.g., \"User follows TDD workflow\", \"User uses git rebase instead of merge\")\n}\n\n/**\n * Long-term memory entry\n */\nexport interface LongTermMemory {\n id: UUID;\n agentId: UUID;\n entityId: UUID; // The user/entity this memory is about\n category: LongTermMemoryCategory;\n content: string; // The actual memory content\n metadata?: Record<string, unknown>; // Additional structured data\n embedding?: number[]; // Vector embedding for semantic search\n confidence?: number; // Confidence score (0-1)\n source?: string; // Where this memory came from (conversation, manual, etc.)\n createdAt: Date;\n updatedAt: Date;\n lastAccessedAt?: Date;\n accessCount?: number;\n similarity?: number; // Optional similarity score from vector search\n}\n\n/**\n * Short-term memory session summary\n */\nexport interface SessionSummary {\n id: UUID;\n agentId: UUID;\n roomId: UUID;\n entityId?: UUID; // Optional: specific user in the session\n summary: string; // The summarized conversation\n messageCount: number; // Number of messages summarized\n lastMessageOffset: number; // Index of last summarized message (for pagination)\n startTime: Date; // Timestamp of first message\n endTime: Date; // Timestamp of last message\n topics?: string[]; // Main topics discussed\n metadata?: Record<string, unknown>;\n embedding?: number[]; // Vector embedding of the summary\n createdAt: Date;\n updatedAt: Date; // Track when summary was last updated\n}\n\n/**\n * Configuration for memory plugin\n */\nexport interface MemoryConfig {\n // Short-term memory settings\n shortTermSummarizationThreshold: number; // Messages count before summarization\n shortTermRetainRecent: number; // Number of recent messages to keep after summarization\n shortTermSummarizationInterval: number; // Update summary every N messages after threshold (e.g., 10)\n\n // Long-term memory settings\n longTermExtractionEnabled: boolean;\n longTermVectorSearchEnabled: boolean;\n longTermConfidenceThreshold: number; // Minimum confidence to store\n longTermExtractionThreshold: number; // Minimum messages before starting extraction (default 20)\n longTermExtractionInterval: number; // Run extraction every N messages after threshold (e.g., 5, 10, 15...)\n\n // Summarization settings\n summaryModelType?: string;\n summaryMaxTokens?: number;\n summaryMaxNewMessages?: number; // Max new messages to include in update (prevents context bloat)\n}\n\n/**\n * Memory extraction result from evaluator\n */\nexport interface MemoryExtraction {\n category: LongTermMemoryCategory;\n content: string;\n confidence: number;\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Summary generation result\n */\nexport interface SummaryResult {\n summary: string;\n topics: string[];\n keyPoints: string[];\n}\n",
12
- "import {\n type IAgentRuntime,\n type Memory,\n type Provider,\n type State,\n logger,\n addHeader,\n} from '@elizaos/core';\nimport { MemoryService } from '../services/memory-service';\n\n/**\n * Long-term Memory Provider\n *\n * Provides persistent facts about the user that have been learned across\n * all conversations. This includes:\n * - User identity and roles\n * - Domain expertise\n * - Preferences\n * - Goals and projects\n * - Custom definitions\n * - Behavioral patterns\n *\n * This provider enriches the context with relevant long-term information\n * to make the agent's responses more personalized and contextually aware.\n */\nexport const longTermMemoryProvider: Provider = {\n name: 'LONG_TERM_MEMORY',\n description: 'Persistent facts and preferences about the user',\n position: 50, // Run early to establish user context\n\n get: async (runtime: IAgentRuntime, message: Memory, _state: State) => {\n try {\n const memoryService = runtime.getService('memory') as MemoryService | null;\n if (!memoryService) {\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n\n const { entityId } = message;\n\n // Skip for agent's own messages\n if (entityId === runtime.agentId) {\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n\n // Get long-term memories for this entity\n const memories = await memoryService.getLongTermMemories(entityId, undefined, 25);\n\n if (memories.length === 0) {\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n\n // Format memories using the service's built-in formatter\n const formattedMemories = await memoryService.getFormattedLongTermMemories(entityId);\n\n const text = addHeader('# What I Know About You', formattedMemories);\n\n // Create a summary of memory categories for quick reference\n const categoryCounts = new Map<string, number>();\n for (const memory of memories) {\n const count = categoryCounts.get(memory.category) || 0;\n categoryCounts.set(memory.category, count + 1);\n }\n\n const categoryList = Array.from(categoryCounts.entries())\n .map(([cat, count]) => `${cat}: ${count}`)\n .join(', ');\n\n return {\n data: {\n memories,\n categoryCounts: Object.fromEntries(categoryCounts),\n },\n values: {\n longTermMemories: text,\n memoryCategories: categoryList,\n },\n text,\n };\n } catch (error) {\n logger.error({ error }, 'Error in longTermMemoryProvider:');\n return {\n data: { memories: [] },\n values: { longTermMemories: '' },\n text: '',\n };\n }\n },\n};\n",
13
- "import {\n type IAgentRuntime,\n type Memory,\n type Provider,\n type State,\n addHeader,\n logger,\n} from '@elizaos/core';\nimport { MemoryService } from '../services/memory-service';\n\n/**\n * Context Summary Provider\n *\n * Provides summarized context from previous conversations.\n * Returns session summaries with and without topics for flexible usage.\n *\n * Values returned:\n * - sessionSummaries: Summary text only (without topics)\n * - sessionSummariesWithTopics: Summary text with topics included\n */\nexport const contextSummaryProvider: Provider = {\n name: 'SUMMARIZED_CONTEXT',\n description: 'Provides summarized context from previous conversations',\n position: 96,\n\n get: async (runtime: IAgentRuntime, message: Memory, _state: State) => {\n try {\n const memoryService = runtime.getService('memory') as MemoryService | null;\n const { roomId } = message;\n\n // If no memory service, return empty\n if (!memoryService) {\n return {\n data: {\n summary: null,\n },\n values: {\n sessionSummaries: '',\n sessionSummariesWithTopics: '',\n },\n text: '',\n };\n }\n\n // Get current session summary\n const currentSummary = await memoryService.getCurrentSessionSummary(roomId);\n\n if (!currentSummary) {\n return {\n data: {\n summary: null,\n },\n values: {\n sessionSummaries: '',\n sessionSummariesWithTopics: '',\n },\n text: '',\n };\n }\n\n // Format summary without topics\n const messageRange = `${currentSummary.messageCount} messages`;\n const timeRange = new Date(currentSummary.startTime).toLocaleDateString();\n\n let summaryOnly = `**Previous Conversation** (${messageRange}, ${timeRange})\\n`;\n summaryOnly += currentSummary.summary;\n\n // Format summary with topics\n let summaryWithTopics = summaryOnly;\n if (currentSummary.topics && currentSummary.topics.length > 0) {\n summaryWithTopics += `\\n*Topics: ${currentSummary.topics.join(', ')}*`;\n }\n\n const sessionSummaries = addHeader('# Conversation Summary', summaryOnly);\n const sessionSummariesWithTopics = addHeader('# Conversation Summary', summaryWithTopics);\n\n return {\n data: {\n summary: currentSummary,\n },\n values: {\n sessionSummaries,\n sessionSummariesWithTopics,\n },\n text: sessionSummariesWithTopics,\n };\n } catch (error) {\n logger.error({ error }, 'Error in contextSummaryProvider:');\n return {\n data: {\n summary: null,\n },\n values: {\n sessionSummaries: '',\n sessionSummariesWithTopics: '',\n },\n text: '',\n };\n }\n },\n};\n",
14
- "import {\n addHeader,\n ChannelType,\n CustomMetadata,\n formatMessages,\n formatPosts,\n getEntityDetails,\n type Entity,\n type IAgentRuntime,\n type Memory,\n type Provider,\n type State,\n logger,\n} from \"@elizaos/core\";\nimport { MemoryService } from \"../services/memory-service\";\n\n/**\n * Recent Messages Provider\n *\n * Provides recent conversation messages with detailed context.\n * Fetches the most recent unsummarized messages from the conversation.\n *\n * Values returned:\n * - recentMessages: Formatted recent messages\n * - conversationLog: Simple timestamped conversation log\n * - conversationLogWithAgentThoughts: Conversation log including agent's internal thoughts\n * - receivedMessageHeader: Header showing the current message being responded to\n * - focusHeader: Instruction to focus response on the received message\n */\nexport const recentMessagesProvider: Provider = {\n name: \"RECENT_MESSAGES\",\n description: \"Provides recent conversation messages with detailed context\",\n position: 94,\n\n get: async (runtime: IAgentRuntime, message: Memory, _state: State) => {\n try {\n const memoryService = runtime.getService(\n \"memory\"\n ) as MemoryService | null;\n const { roomId } = message;\n\n // Get configuration\n const config = memoryService?.getConfig() || {\n shortTermSummarizationThreshold: 16,\n shortTermRetainRecent: 6,\n };\n\n // Get conversation length setting\n const conversationLength = runtime.getConversationLength();\n\n // Determine how many messages to fetch and from where\n let messagesToFetch = config.shortTermRetainRecent;\n let startOffset = 0;\n\n // Check if we have a summary to determine offset and whether to use summarization mode\n let hasSummary = false;\n if (memoryService) {\n const currentSummary = await memoryService.getCurrentSessionSummary(\n roomId\n );\n if (currentSummary) {\n hasSummary = true;\n // When we have a summary, fetch recent messages after the summary offset\n startOffset = currentSummary.lastMessageOffset || 0;\n }\n }\n\n // If no summary exists, check if we should show all messages or just recent ones\n if (!hasSummary) {\n // Get all messages to count dialogue messages\n const allMessages = await runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: conversationLength,\n unique: false,\n });\n\n const dialogueMessageCount = allMessages.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n ).length;\n\n // If below threshold, show all messages; otherwise show recent only\n if (dialogueMessageCount < config.shortTermSummarizationThreshold) {\n messagesToFetch = conversationLength;\n }\n }\n\n // Parallelize data fetching\n const [entitiesData, room, recentMessagesData] = await Promise.all([\n getEntityDetails({ runtime, roomId }),\n runtime.getRoom(roomId),\n runtime.getMemories({\n tableName: \"messages\",\n roomId,\n count: messagesToFetch,\n unique: false,\n start: startOffset,\n }),\n ]);\n\n // Determine format based on room type\n const isPostFormat = room?.type\n ? room.type === ChannelType.FEED || room.type === ChannelType.THREAD\n : false;\n\n // Filter to dialogue messages only (exclude action results)\n const dialogueMessages = recentMessagesData.filter(\n (msg) =>\n !(\n msg.content?.type === \"action_result\" &&\n msg.metadata?.type === \"action_result\"\n ) &&\n (msg.metadata?.type === \"agent_response_message\" ||\n msg.metadata?.type === \"user_message\")\n );\n\n // Format recent messages\n let recentMessagesText = \"\";\n if (dialogueMessages.length > 0) {\n if (isPostFormat) {\n recentMessagesText = formatPosts({\n messages: dialogueMessages,\n entities: entitiesData,\n conversationHeader: false,\n });\n } else {\n recentMessagesText = formatMessages({\n messages: dialogueMessages,\n entities: entitiesData,\n });\n }\n\n if (recentMessagesText) {\n recentMessagesText = addHeader(\n \"# Recent Messages\",\n recentMessagesText\n );\n }\n }\n\n // Format conversation logs (simple format without IDs)\n const formatConversationLog = (\n messages: Memory[],\n includeThoughts: boolean\n ): string => {\n return messages\n .sort((a, b) => (a.createdAt || 0) - (b.createdAt || 0))\n .map((msg) => {\n const entity = entitiesData.find(\n (e: Entity) => e.id === msg.entityId\n );\n const entityName =\n entity?.names[0] ||\n (msg.entityId === runtime.agentId\n ? runtime.character.name\n : \"Unknown\");\n const timestamp = msg.createdAt\n ? new Date(msg.createdAt).toLocaleString()\n : \"Unknown time\";\n\n const text = msg.content.text || \"\";\n const thought =\n includeThoughts && msg.content.thought\n ? `\\n [Internal thought: ${msg.content.thought}]`\n : \"\";\n\n return `[${timestamp}] ${entityName}: ${text}${thought}`;\n })\n .join(\"\\n\");\n };\n\n const conversationLog = addHeader(\n \"# Conversation Messages\",\n formatConversationLog(dialogueMessages, false)\n );\n const conversationLogWithAgentThoughts = addHeader(\n \"# Conversation Messages\",\n formatConversationLog(dialogueMessages, true)\n );\n\n // Build received message header\n const metaData = message.metadata as CustomMetadata;\n const senderName =\n entitiesData.find((entity: Entity) => entity.id === message.entityId)\n ?.names[0] ||\n metaData?.entityName ||\n \"Unknown User\";\n const receivedMessageContent = message.content.text;\n const hasReceivedMessage = !!receivedMessageContent?.trim();\n\n const receivedMessageHeader = hasReceivedMessage\n ? addHeader(\n \"# Received Message\",\n `${senderName}: ${receivedMessageContent}`\n )\n : \"\";\n\n const focusHeader = hasReceivedMessage\n ? addHeader(\n \"# Focus your response\",\n `You are replying to the above message from **${senderName}**. Keep your answer relevant to that message.`\n )\n : \"\";\n\n // Combine sections for text output\n const text = [recentMessagesText, receivedMessageHeader, focusHeader]\n .filter(Boolean)\n .join(\"\\n\\n\");\n\n return {\n data: {\n messages: dialogueMessages,\n },\n values: {\n recentMessages: recentMessagesText,\n conversationLog,\n conversationLogWithAgentThoughts,\n ...(receivedMessageHeader && { receivedMessageHeader }),\n ...(focusHeader && { focusHeader }),\n },\n text,\n };\n } catch (error) {\n logger.error({ error }, \"Error in recentMessagesProvider:\");\n return {\n data: {\n messages: [],\n },\n values: {\n recentMessages: \"\",\n conversationLog: \"\",\n conversationLogWithAgentThoughts: \"\",\n receivedMessageHeader: \"\",\n focusHeader: \"\",\n },\n text: \"\",\n };\n }\n },\n};\n",
15
- "import type { Plugin } from '@elizaos/core';\nimport { MemoryService } from './services/memory-service';\nimport { summarizationEvaluator } from './evaluators/summarization';\nimport { longTermExtractionEvaluator } from './evaluators/long-term-extraction';\n// import { shortTermMemoryProvider } from './providers/short-term-memory';\nimport { longTermMemoryProvider } from './providers/long-term-memory';\nimport { contextSummaryProvider } from './providers/context-summary';\nimport { recentMessagesProvider } from './providers/recent-messages';\n// import { rememberAction } from './actions/remember';\nimport * as schema from './schemas/index';\n\nexport * from './types/index';\nexport * from './schemas/index';\nexport { MemoryService } from './services/memory-service';\nexport { contextSummaryProvider } from './providers/context-summary';\nexport { recentMessagesProvider } from './providers/recent-messages';\nexport { longTermMemoryProvider } from './providers/long-term-memory';\n\n/**\n * Memory Plugin\n *\n * Advanced memory management plugin that provides:\n *\n * **Short-term Memory (Conversation Summarization)**:\n * - Automatically summarizes long conversations to reduce context size\n * - Retains recent messages while archiving older ones as summaries\n * - Configurable thresholds for when to summarize\n *\n * **Long-term Memory (Persistent Facts)**:\n * - Extracts and stores persistent facts about users\n * - Categorizes information (identity, expertise, preferences, etc.)\n * - Provides context-aware user profiles across all conversations\n *\n * **Components**:\n * - `MemoryService`: Manages all memory operations\n * - Evaluators: Process conversations to create summaries and extract facts\n * - Providers: Inject memory context into conversations\n * - Actions: Allow manual memory storage via user commands\n *\n * **Configuration** (via environment variables):\n * - `MEMORY_SUMMARIZATION_THRESHOLD`: Messages before summarization (default: 50)\n * - `MEMORY_RETAIN_RECENT`: Recent messages to keep (default: 10)\n * - `MEMORY_LONG_TERM_ENABLED`: Enable long-term extraction (default: true)\n * - `MEMORY_CONFIDENCE_THRESHOLD`: Minimum confidence to store (default: 0.7)\n *\n * **Database Tables**:\n * - `long_term_memories`: Persistent user facts\n * - `session_summaries`: Conversation summaries\n * - `memory_access_logs`: Optional usage tracking\n */\nexport const memoryPlugin: Plugin = {\n name: 'memory',\n description:\n 'Advanced memory management with conversation summarization and long-term persistent memory',\n\n services: [MemoryService],\n\n evaluators: [summarizationEvaluator, longTermExtractionEvaluator],\n\n providers: [\n longTermMemoryProvider, \n // shortTermMemoryProvider, \n contextSummaryProvider, \n recentMessagesProvider\n ],\n\n // actions: [rememberAction],\n\n // Export schema for dynamic migrations\n schema,\n};\n\nexport default memoryPlugin;\n"
16
- ],
17
- "mappings": "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",
18
- "debugId": "007D7F9163530F2964756E2164756E21",
19
- "names": []
20
- }
@@ -1,15 +0,0 @@
1
- import { type Provider } from "@elizaos/core";
2
- /**
3
- * Recent Messages Provider
4
- *
5
- * Provides recent conversation messages with detailed context.
6
- * Fetches the most recent unsummarized messages from the conversation.
7
- *
8
- * Values returned:
9
- * - recentMessages: Formatted recent messages
10
- * - conversationLog: Simple timestamped conversation log
11
- * - conversationLogWithAgentThoughts: Conversation log including agent's internal thoughts
12
- * - receivedMessageHeader: Header showing the current message being responded to
13
- * - focusHeader: Instruction to focus response on the received message
14
- */
15
- export declare const recentMessagesProvider: Provider;