--- title: "Claude Memory Tool" description: "Enable Claude's persistent memory capabilities with Supermemory as the backend" --- Enable Claude's native memory tool functionality with Supermemory as the persistent storage backend. Claude can automatically store and retrieve information across conversations using familiar filesystem operations. Check out the NPM page for more details ## Installation ```bash npm install @supermemory/tools @anthropic-ai/sdk ``` ## Quick Start ```typescript import Anthropic from "@anthropic-ai/sdk" import { createClaudeMemoryTool } from "@supermemory/tools/claude-memory" const anthropic = new Anthropic({ apiKey: process.env.ANTHROPIC_API_KEY!, }) const memoryTool = createClaudeMemoryTool(process.env.SUPERMEMORY_API_KEY!, { projectId: 'my-app', }) async function chatWithMemory(userMessage: string) { const response = await anthropic.beta.messages.create({ model: 'claude-sonnet-4-5', max_tokens: 8096, tools: [{ type: 'memory_20250818', name: 'memory' }], betas: ['context-management-2025-06-27'], messages: [{ role: 'user', content: userMessage }], }) // Handle memory tool calls for (const block of response.content) { if (block.type === 'tool_use' && block.name === 'memory') { const result = await memoryTool.handleCommandForToolResult( block.input as MemoryCommand, block.id ) console.log('Memory operation result:', result) } } return response } ``` ## How It Works Claude's memory tool uses a filesystem metaphor to manage persistent information: - **Files**: Individual memory items stored as Supermemory documents - **Directories**: Organized using path structure (e.g., `/memories/user-preferences`) - **Operations**: View, create, edit, delete, and rename files - **Path Normalization**: Paths like `/memories/preferences` are stored as `--memories--preferences` ## Configuration ### Basic Configuration ```typescript import { createClaudeMemoryTool } from "@supermemory/tools/claude-memory" const memoryTool = createClaudeMemoryTool( process.env.SUPERMEMORY_API_KEY!, { projectId: 'my-app', // Project identifier baseUrl: 'https://api.supermemory.ai', // Optional: custom API endpoint } ) ``` ### Using Container Tags ```typescript const memoryTool = createClaudeMemoryTool( process.env.SUPERMEMORY_API_KEY!, { containerTags: ['user:alice', 'app:chat'], } ) ``` ## Memory Operations Claude automatically performs these operations when managing memory: ### View Files List directory contents or read file contents: ```typescript // Claude will automatically check /memories/ directory // This maps to searching Supermemory documents with path prefix ``` ### Create Files Store new information: ```typescript // Claude creates: /memories/user-preferences.txt // Stored as document with customId: "--memories--user-preferences.txt" ``` ### Edit Files Update existing memories using string replacement: ```typescript // Claude performs str_replace on file contents // Updates the corresponding Supermemory document ``` ### Delete Files Remove information: ```typescript // Claude deletes: /memories/old-data.txt // Removes document from Supermemory ``` ### Rename Files Reorganize memory structure: ```typescript // Claude renames: /memories/temp.txt -> /memories/final.txt // Updates document customId in Supermemory ``` ## Complete Chat Example Here's a full example with conversation handling: ```typescript import Anthropic from "@anthropic-ai/sdk" import { createClaudeMemoryTool, type MemoryCommand } from "@supermemory/tools/claude-memory" const anthropic = new Anthropic({ apiKey: process.env.ANTHROPIC_API_KEY!, }) const memoryTool = createClaudeMemoryTool(process.env.SUPERMEMORY_API_KEY!, { projectId: 'chat-app', }) async function chat() { const messages: Anthropic.MessageParam[] = [] // First message: store information messages.push({ role: 'user', content: 'Remember that I prefer dark mode and use TypeScript' }) let response = await anthropic.beta.messages.create({ model: 'claude-sonnet-4-5', max_tokens: 8096, tools: [{ type: 'memory_20250818', name: 'memory' }], betas: ['context-management-2025-06-27'], messages, }) // Process tool calls const toolResults: Anthropic.ToolResultBlockParam[] = [] for (const block of response.content) { if (block.type === 'tool_use' && block.name === 'memory') { const result = await memoryTool.handleCommandForToolResult( block.input as MemoryCommand, block.id ) toolResults.push(result) } } // Continue conversation with tool results if (toolResults.length > 0) { messages.push({ role: 'assistant', content: response.content }) messages.push({ role: 'user', content: toolResults }) response = await anthropic.beta.messages.create({ model: 'claude-sonnet-4-5', max_tokens: 8096, tools: [{ type: 'memory_20250818', name: 'memory' }], betas: ['context-management-2025-06-27'], messages, }) } console.log(response.content) } chat() ``` ## Advanced Usage ### Custom Path Management Control where Claude stores information: ```typescript // Claude automatically organizes by path // /memories/preferences/editor.txt // /memories/projects/current.txt // /memories/notes/meeting-2024.txt // Each path is normalized and stored with appropriate metadata ``` ### Error Handling Handle operations gracefully: ```typescript const result = await memoryTool.handleCommandForToolResult(command, toolUseId) if (result.is_error) { console.error('Memory operation failed:', result.content) // Handle error appropriately } else { console.log('Success:', result.content) } ``` ### Monitoring Operations Track memory operations: ```typescript for (const block of response.content) { if (block.type === 'tool_use' && block.name === 'memory') { console.log('Operation:', block.input.command) console.log('Path:', block.input.path) const result = await memoryTool.handleCommandForToolResult( block.input as MemoryCommand, block.id ) console.log('Result:', result.is_error ? 'Failed' : 'Success') } } ``` ## Memory Organization ### Best Practices 1. **Use Descriptive Paths**: `/memories/user-preferences/theme.txt` is better than `/mem1.txt` 2. **Organize by Category**: Group related information under directories 3. **Keep Files Focused**: Store specific information in separate files 4. **Use Clear Naming**: Make file names self-explanatory ### Path Structure Examples ``` /memories/ ├── user-profile/ │ ├── name.txt │ ├── preferences.txt │ └── settings.txt ├── projects/ │ ├── current-task.txt │ └── goals.txt └── notes/ ├── meeting-notes.txt └── ideas.txt ``` ## API Reference ### `createClaudeMemoryTool(apiKey, config)` Creates a memory tool instance for Claude. **Parameters:** - `apiKey` (string): Your Supermemory API key - `config` (optional): - `projectId` (string): Project identifier - `containerTags` (string[]): Alternative to projectId - `baseUrl` (string): Custom API endpoint **Returns:** `ClaudeMemoryTool` instance ### `handleCommandForToolResult(command, toolUseId)` Processes a memory command and returns formatted result. **Parameters:** - `command` (MemoryCommand): The memory operation from Claude - `toolUseId` (string): Tool use ID from Claude's response **Returns:** `Promise` with: - `type`: "tool_result" - `tool_use_id`: The tool use ID - `content`: Operation result or error message - `is_error`: Boolean indicating success/failure ## Memory Commands Claude uses these command types internally: | Command | Description | Example | |---------|-------------|---------| | `view` | List directory or read file | `/memories/` or `/memories/file.txt` | | `create` | Create new file | Create `/memories/new.txt` with content | | `str_replace` | Edit file contents | Replace "old text" with "new text" | | `insert` | Add content at line | Insert at line 5 | | `delete` | Remove file | Delete `/memories/old.txt` | | `rename` | Rename/move file | Rename `old.txt` to `new.txt` | ## Environment Variables ```bash ANTHROPIC_API_KEY=your_anthropic_key SUPERMEMORY_API_KEY=your_supermemory_key ``` ## When to Use The Claude Memory Tool is ideal for: - **Conversational AI**: Claude automatically remembers user preferences and context - **Personal Assistants**: Store and retrieve user-specific information - **Documentation Bots**: Maintain knowledge across conversations - **Project Management**: Track tasks and project state - **Note-Taking Apps**: Persistent memory for meeting notes and ideas ## Comparison with Other Approaches | Feature | Claude Memory Tool | OpenAI SDK Tools | AI SDK Tools | |---------|-------------------|------------------|--------------| | Automatic Memory | ✅ Claude decides | ❌ Manual control | ❌ Manual control | | Filesystem Metaphor | ✅ Files/directories | ❌ Flat storage | ❌ Flat storage | | Path Organization | ✅ Hierarchical | ❌ Tags only | ❌ Tags only | | Integration | Anthropic SDK only | OpenAI SDK only | Vercel AI SDK | ## Limitations - Requires Anthropic SDK with beta features enabled - Path separators (`/`) are normalized to `--` for storage - Maximum 100 files per directory listing - File operations are asynchronous ## Next Steps Use memory tools with OpenAI function calling Integrate with Vercel AI SDK Direct API access for advanced control See real-world examples