@mastra/memory 1.5.1 → 1.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +28 -0
- package/dist/{chunk-6PKWQ3GH.js → chunk-HNPAIFCZ.js} +59 -16
- package/dist/chunk-HNPAIFCZ.js.map +1 -0
- package/dist/{chunk-6XVTMLW4.cjs → chunk-PVFLHAZX.cjs} +59 -16
- package/dist/chunk-PVFLHAZX.cjs.map +1 -0
- package/dist/docs/SKILL.md +55 -0
- package/dist/docs/assets/SOURCE_MAP.json +103 -0
- package/dist/docs/references/docs-agents-agent-approval.md +558 -0
- package/dist/docs/references/docs-agents-agent-memory.md +209 -0
- package/dist/docs/references/docs-agents-network-approval.md +275 -0
- package/dist/docs/references/docs-agents-networks.md +299 -0
- package/dist/docs/references/docs-agents-supervisor-agents.md +304 -0
- package/dist/docs/references/docs-memory-memory-processors.md +314 -0
- package/dist/docs/references/docs-memory-message-history.md +260 -0
- package/dist/docs/references/docs-memory-observational-memory.md +248 -0
- package/dist/docs/references/docs-memory-overview.md +45 -0
- package/dist/docs/references/docs-memory-semantic-recall.md +272 -0
- package/dist/docs/references/docs-memory-storage.md +261 -0
- package/dist/docs/references/docs-memory-working-memory.md +400 -0
- package/dist/docs/references/reference-core-getMemory.md +50 -0
- package/dist/docs/references/reference-core-listMemory.md +56 -0
- package/dist/docs/references/reference-memory-clone-utilities.md +199 -0
- package/dist/docs/references/reference-memory-cloneThread.md +130 -0
- package/dist/docs/references/reference-memory-createThread.md +68 -0
- package/dist/docs/references/reference-memory-getThreadById.md +24 -0
- package/dist/docs/references/reference-memory-listThreads.md +145 -0
- package/dist/docs/references/reference-memory-memory-class.md +147 -0
- package/dist/docs/references/reference-memory-observational-memory.md +565 -0
- package/dist/docs/references/reference-processors-token-limiter-processor.md +115 -0
- package/dist/docs/references/reference-storage-dynamodb.md +282 -0
- package/dist/docs/references/reference-storage-libsql.md +135 -0
- package/dist/docs/references/reference-storage-mongodb.md +262 -0
- package/dist/docs/references/reference-storage-postgresql.md +526 -0
- package/dist/docs/references/reference-storage-upstash.md +160 -0
- package/dist/docs/references/reference-vectors-libsql.md +305 -0
- package/dist/docs/references/reference-vectors-mongodb.md +295 -0
- package/dist/docs/references/reference-vectors-pg.md +408 -0
- package/dist/docs/references/reference-vectors-upstash.md +294 -0
- package/dist/index.cjs +1 -1
- package/dist/index.js +1 -1
- package/dist/{observational-memory-AJWSMZVP.js → observational-memory-KAFD4QZK.js} +3 -3
- package/dist/{observational-memory-AJWSMZVP.js.map → observational-memory-KAFD4QZK.js.map} +1 -1
- package/dist/{observational-memory-Q5TO525O.cjs → observational-memory-Q47HN5YL.cjs} +17 -17
- package/dist/{observational-memory-Q5TO525O.cjs.map → observational-memory-Q47HN5YL.cjs.map} +1 -1
- package/dist/processors/index.cjs +15 -15
- package/dist/processors/index.js +1 -1
- package/dist/processors/observational-memory/observational-memory.d.ts +2 -2
- package/dist/processors/observational-memory/observational-memory.d.ts.map +1 -1
- package/dist/processors/observational-memory/token-counter.d.ts.map +1 -1
- package/package.json +8 -8
- package/dist/chunk-6PKWQ3GH.js.map +0 -1
- package/dist/chunk-6XVTMLW4.cjs.map +0 -1
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
# Memory Class
|
|
2
|
+
|
|
3
|
+
The `Memory` class provides a robust system for managing conversation history and thread-based message storage in Mastra. It enables persistent storage of conversations, semantic search capabilities, and efficient message retrieval. You must configure a storage provider for conversation history, and if you enable semantic recall you will also need to provide a vector store and embedder.
|
|
4
|
+
|
|
5
|
+
## Usage example
|
|
6
|
+
|
|
7
|
+
```typescript
|
|
8
|
+
import { Memory } from '@mastra/memory'
|
|
9
|
+
import { Agent } from '@mastra/core/agent'
|
|
10
|
+
|
|
11
|
+
export const agent = new Agent({
|
|
12
|
+
name: 'test-agent',
|
|
13
|
+
instructions: 'You are an agent with memory.',
|
|
14
|
+
model: 'openai/gpt-5.1',
|
|
15
|
+
memory: new Memory({
|
|
16
|
+
options: {
|
|
17
|
+
workingMemory: {
|
|
18
|
+
enabled: true,
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
}),
|
|
22
|
+
})
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
> To enable `workingMemory` on an agent, you’ll need a storage provider configured on your main Mastra instance. See [Mastra class](https://mastra.ai/reference/core/mastra-class) for more information.
|
|
26
|
+
|
|
27
|
+
## Constructor parameters
|
|
28
|
+
|
|
29
|
+
**storage?:** (`MastraCompositeStore`): Storage implementation for persisting memory data. Defaults to \`new DefaultStorage({ config: { url: "file:memory.db" } })\` if not provided.
|
|
30
|
+
|
|
31
|
+
**vector?:** (`MastraVector | false`): Vector store for semantic search capabilities. Set to \`false\` to disable vector operations.
|
|
32
|
+
|
|
33
|
+
**embedder?:** (`EmbeddingModel<string> | EmbeddingModelV2<string>`): Embedder instance for vector embeddings. Required when semantic recall is enabled.
|
|
34
|
+
|
|
35
|
+
**options?:** (`MemoryConfig`): Memory configuration options.
|
|
36
|
+
|
|
37
|
+
### Options parameters
|
|
38
|
+
|
|
39
|
+
**lastMessages?:** (`number | false`): Number of most recent messages to include in context. Set to \`false\` to disable loading conversation history into context. Use \`Number.MAX\_SAFE\_INTEGER\` to retrieve all messages with no limit. To prevent saving new messages, use the \`readOnly\` option instead. (Default: `10`)
|
|
40
|
+
|
|
41
|
+
**readOnly?:** (`boolean`): When true, prevents memory from saving new messages and provides working memory as read-only context (without the updateWorkingMemory tool). Useful for read-only operations like previews, internal routing agents, or sub agents that should reference but not modify memory. (Default: `false`)
|
|
42
|
+
|
|
43
|
+
**semanticRecall?:** (`boolean | { topK: number; messageRange: number | { before: number; after: number }; scope?: 'thread' | 'resource' }`): Enable semantic search in message history. Can be a boolean or an object with configuration options. When enabled, requires both vector store and embedder to be configured. Default topK is 4, default messageRange is {before: 1, after: 1}. (Default: `false`)
|
|
44
|
+
|
|
45
|
+
**workingMemory?:** (`WorkingMemory`): Configuration for working memory feature. Can be \`{ enabled: boolean; template?: string; schema?: ZodObject\<any> | JSONSchema7; scope?: 'thread' | 'resource' }\` or \`{ enabled: boolean }\` to disable. (Default: `{ enabled: false, template: '# User Information\n- **First Name**:\n- **Last Name**:\n...' }`)
|
|
46
|
+
|
|
47
|
+
**observationalMemory?:** (`boolean | ObservationalMemoryOptions`): Enable Observational Memory for long-context agentic memory. Set to \`true\` for defaults, or pass a config object to customize token budgets, models, and scope. See \[Observational Memory reference]\(/reference/memory/observational-memory) for configuration details. (Default: `false`)
|
|
48
|
+
|
|
49
|
+
**generateTitle?:** (`boolean | { model: DynamicArgument<MastraLanguageModel>; instructions?: DynamicArgument<string> }`): Controls automatic thread title generation from the user's first message. Can be a boolean or an object with custom model and instructions. (Default: `false`)
|
|
50
|
+
|
|
51
|
+
## Returns
|
|
52
|
+
|
|
53
|
+
**memory:** (`Memory`): A new Memory instance with the specified configuration.
|
|
54
|
+
|
|
55
|
+
## Extended usage example
|
|
56
|
+
|
|
57
|
+
```typescript
|
|
58
|
+
import { Memory } from '@mastra/memory'
|
|
59
|
+
import { Agent } from '@mastra/core/agent'
|
|
60
|
+
import { LibSQLStore, LibSQLVector } from '@mastra/libsql'
|
|
61
|
+
|
|
62
|
+
export const agent = new Agent({
|
|
63
|
+
name: 'test-agent',
|
|
64
|
+
instructions: 'You are an agent with memory.',
|
|
65
|
+
model: 'openai/gpt-5.1',
|
|
66
|
+
memory: new Memory({
|
|
67
|
+
storage: new LibSQLStore({
|
|
68
|
+
id: 'test-agent-storage',
|
|
69
|
+
url: 'file:./working-memory.db',
|
|
70
|
+
}),
|
|
71
|
+
vector: new LibSQLVector({
|
|
72
|
+
id: 'test-agent-vector',
|
|
73
|
+
url: 'file:./vector-memory.db',
|
|
74
|
+
}),
|
|
75
|
+
options: {
|
|
76
|
+
lastMessages: 10,
|
|
77
|
+
semanticRecall: {
|
|
78
|
+
topK: 3,
|
|
79
|
+
messageRange: 2,
|
|
80
|
+
scope: 'resource',
|
|
81
|
+
},
|
|
82
|
+
workingMemory: {
|
|
83
|
+
enabled: true,
|
|
84
|
+
},
|
|
85
|
+
generateTitle: true,
|
|
86
|
+
},
|
|
87
|
+
}),
|
|
88
|
+
})
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
## PostgreSQL with index configuration
|
|
92
|
+
|
|
93
|
+
```typescript
|
|
94
|
+
import { Memory } from '@mastra/memory'
|
|
95
|
+
import { Agent } from '@mastra/core/agent'
|
|
96
|
+
import { ModelRouterEmbeddingModel } from '@mastra/core/llm'
|
|
97
|
+
import { PgStore, PgVector } from '@mastra/pg'
|
|
98
|
+
|
|
99
|
+
export const agent = new Agent({
|
|
100
|
+
name: 'pg-agent',
|
|
101
|
+
instructions: 'You are an agent with optimized PostgreSQL memory.',
|
|
102
|
+
model: 'openai/gpt-5.1',
|
|
103
|
+
memory: new Memory({
|
|
104
|
+
storage: new PgStore({
|
|
105
|
+
id: 'pg-agent-storage',
|
|
106
|
+
connectionString: process.env.DATABASE_URL,
|
|
107
|
+
}),
|
|
108
|
+
vector: new PgVector({
|
|
109
|
+
id: 'pg-agent-vector',
|
|
110
|
+
connectionString: process.env.DATABASE_URL,
|
|
111
|
+
}),
|
|
112
|
+
embedder: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
|
|
113
|
+
options: {
|
|
114
|
+
lastMessages: 20,
|
|
115
|
+
semanticRecall: {
|
|
116
|
+
topK: 5,
|
|
117
|
+
messageRange: 3,
|
|
118
|
+
scope: 'resource',
|
|
119
|
+
indexConfig: {
|
|
120
|
+
type: 'hnsw', // Use HNSW for better performance
|
|
121
|
+
metric: 'dotproduct', // Optimal for OpenAI embeddings
|
|
122
|
+
m: 16, // Number of bi-directional links
|
|
123
|
+
efConstruction: 64, // Construction-time candidate list size
|
|
124
|
+
},
|
|
125
|
+
},
|
|
126
|
+
workingMemory: {
|
|
127
|
+
enabled: true,
|
|
128
|
+
},
|
|
129
|
+
},
|
|
130
|
+
}),
|
|
131
|
+
})
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### Related
|
|
135
|
+
|
|
136
|
+
- [Getting Started with Memory](https://mastra.ai/docs/memory/overview)
|
|
137
|
+
- [Semantic Recall](https://mastra.ai/docs/memory/semantic-recall)
|
|
138
|
+
- [Working Memory](https://mastra.ai/docs/memory/working-memory)
|
|
139
|
+
- [Observational Memory](https://mastra.ai/docs/memory/observational-memory)
|
|
140
|
+
- [Memory Processors](https://mastra.ai/docs/memory/memory-processors)
|
|
141
|
+
- [createThread](https://mastra.ai/reference/memory/createThread)
|
|
142
|
+
- [recall](https://mastra.ai/reference/memory/recall)
|
|
143
|
+
- [getThreadById](https://mastra.ai/reference/memory/getThreadById)
|
|
144
|
+
- [listThreads](https://mastra.ai/reference/memory/listThreads)
|
|
145
|
+
- [deleteMessages](https://mastra.ai/reference/memory/deleteMessages)
|
|
146
|
+
- [cloneThread](https://mastra.ai/reference/memory/cloneThread)
|
|
147
|
+
- [Clone Utility Methods](https://mastra.ai/reference/memory/clone-utilities)
|