Samantha

Samantha

MCP server that dynamically extracts and manages user memory from LLM conversations, enabling consistent personalization across different models.

Category
Visit Server

README

Samantha: MCP Memory Manager

License: MIT Docker MCP Python 3.11

</div>

šŸ“š Overview

Samantha is a sophisticated MCP (Model Context Protocol) server that dynamically extracts and manages user memory from LLM conversations. This memory can be shared across different LLMs, allowing for consistent personalization even when switching between models.

Samantha analyzes conversations, extracting information about learning styles, topics of interest, knowledge levels, and personal preferences, creating a comprehensive user profile that LLMs can use to provide tailored responses.

🌟 Key Features

  • Dynamic Memory Extraction - Automatically identifies learning styles, topics, and preferences from conversations
  • Learning Style Analysis - Uses the VARK model (Visual, Auditory, Reading/Writing, Kinesthetic) with detailed recommendations
  • Topic Relationship Mapping - Creates connection graphs between knowledge areas
  • Personal Preference Tracking - Records and ranks preferences in categories like movies, books, and music
  • System Prompt Memory - Stores effective system prompts with effectiveness ratings
  • Interactive Dashboard - Visualizes and manages memory profiles
  • Multi-format Export/Import - Supports JSON, MentorSync, and LLM-friendly formats
  • Docker Integration - Runs in isolated containers with persistent storage

šŸ”§ System Requirements

  • Docker and Docker Compose
  • 512MB RAM minimum (recommend 1GB+)
  • 1GB disk space
  • For direct installation: Python 3.11+

šŸ“‹ Memory Layers

Samantha uses a multi-layered memory architecture:

  1. Identity Layer - Core user identity
  2. Learning Style Layer - VARK profile with weighted representations
  3. Knowledge Layer - Topics with mastery levels and relationships
  4. Preference Layer - Category-based preference tracking with scoring
  5. Interaction Layer - Conversation style preferences
  6. System Layer - Effective system prompts with effectiveness scores

šŸ’¾ Docker Memory Requirements

  • Base Image: ~500MB
  • Runtime Memory: 300-500MB (depends on number of active users)
  • Storage: Minimal (~1KB per user profile)
  • Total: ~1GB recommended allocation

šŸš€ Quick Start

Using Docker (Recommended)

# Clone the repository
git clone https://github.com/yourusername/samantha-mcp.git
cd samantha-mcp

# Start the services
docker-compose up -d

# Access the dashboard
open http://localhost:8501

Manual Installation

# Clone the repository
git clone https://github.com/yourusername/samantha-mcp.git
cd samantha-mcp

# Create a virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt

# Download spaCy model
python -m spacy download en_core_web_md

# Run the server
python samantha.py

# In a separate terminal, run the dashboard
streamlit run dashboard.py

šŸ—ļø System Architecture

ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”
│                      Claude Desktop                         │
ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”¬ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜
                            │
                 ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā–¼ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”
                 │    MCP Protocol        │
                 ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”¬ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜
                            │
ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”
│                      Samantha Server                        │
│                                                             │
│   ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”    ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”    ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”    │
│   │   Memory    │    │   Memory    │    │    MCP      │    │
│   │  Extractor  │◄───┤    Store    │◄───┤  Interface  │    │
│   ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”¬ā”€ā”€ā”€ā”€ā”€ā”€ā”˜    ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”¬ā”€ā”€ā”€ā”€ā”€ā”€ā”˜    ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”¬ā”€ā”€ā”€ā”€ā”€ā”€ā”˜    │
│          │                  │                  │           │
│   ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā–¼ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā–¼ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā–¼ā”€ā”€ā”€ā”€ā”€ā”€ā”    │
│   │                  Data Models                       │    │
│   │   (Learning Style, Topics, Preferences, etc.)      │    │
│   ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”¬ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜    │
│                           │                                 │
│                     ā”Œā”€ā”€ā”€ā”€ā”€ā–¼ā”€ā”€ā”€ā”€ā”                            │
│                     │   JSON   │                            │
│                     │ Storage  │                            │
│                     ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜                            │
ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜
                            │
                  ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā–¼ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”
                  │ Streamlit        │
                  │   Dashboard      │
                  ā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜

šŸ“¦ File Structure

samantha-mcp/
ā”œā”€ā”€ samantha.py         # Core MCP server implementation
ā”œā”€ā”€ dashboard.py        # Streamlit dashboard
ā”œā”€ā”€ Dockerfile          # Container definition
ā”œā”€ā”€ docker-compose.yml  # Container orchestration
ā”œā”€ā”€ requirements.txt    # Python dependencies
ā”œā”€ā”€ setup.sh            # Setup script
ā”œā”€ā”€ data/               # Persistent storage directory
└── docs/               # Documentation

šŸ”Œ MCP Integration

Resources

Resource Path Description
memory://{user_id}/profile Complete user memory profile
memory://{user_id}/learning_style VARK learning style with recommendations
memory://{user_id}/topics Knowledge topics and mastery levels
memory://{user_id}/system_prompts Effective system prompts
memory://{user_id}/preferences/{category} Specific preference category
memory://{user_id}/conversation_style Communication style preferences

Tools

Tool Name Description
extract_memory Extract memory from a conversation
add_system_prompt Add a new system prompt
update_system_prompt_effectiveness Update system prompt effectiveness rating
update_topic_mastery Update topic mastery level
relate_topics Establish relationships between topics
update_learning_style Manually update learning style
export_memory Export user memory in specified format
import_memory Import user memory from specified format
delete_user_memory Delete a user's memory

šŸ”„ Memory Extraction Process

The memory extraction process involves:

  1. Conversation Analysis: Processing text for learning style indicators, topic mentions, and preferences
  2. Pattern Matching: Identifying learning patterns using NLP techniques
  3. Weighted Updates: Incorporating new insights with a 30/70 weighted model (new/existing)
  4. Profile Construction: Building a comprehensive user profile
  5. Persistent Storage: Saving memory in JSON format for retrieval

šŸŽ® Dashboard Features

The interactive Streamlit dashboard provides:

  • User Profile Overview: Summary of all memory components
  • Learning Style Management: Visual editors for VARK profiles
  • Topic Network Visualization: Interactive graph of knowledge areas
  • System Prompt Library: Create and rate effective prompts
  • Preference Management: Track and organize user likes
  • Import/Export Tools: Data backup and transfer functionality

šŸ”§ Production Deployment

For production deployment, consider:

Docker Swarm/Kubernetes

# Deploy to Docker Swarm
docker stack deploy -c docker-compose.yml samantha

# Or with Kubernetes
kubectl apply -f k8s-deployment.yml

Multiple Instances with Load Balancing

# Example docker-compose.override.yml
services:
  samantha:
    deploy:
      replicas: 3
  
  nginx:
    image: nginx:latest
    ports:
      - "80:80"
    volumes:
      - ./nginx.conf:/etc/nginx/nginx.conf
    depends_on:
      - samantha

Data Volume Management

The data directory contains all user profiles and should be backed up regularly:

# Backup data
tar -czf samantha-data-backup.tar.gz data/

# Restore data
tar -xzf samantha-data-backup.tar.gz

šŸ” Troubleshooting

Common Issues

Issue Solution
Port conflicts Modify port mappings in docker-compose.yml
Memory errors Increase container memory limits
Missing dependencies Ensure all requirements are installed
Data persistence issues Check volume mounts and permissions
spaCy model errors Manually download with python -m spacy download en_core_web_md

Logs

# View container logs
docker-compose logs -f

# Check specific container
docker logs samantha

šŸ“Š Performance Monitoring

For production deployments, add monitoring:

# With Prometheus/Grafana
docker-compose -f docker-compose.yml -f docker-compose.monitoring.yml up -d

šŸ¤ Contributing

Contributions welcome! Please see CONTRIBUTING.md for details.

šŸ“œ License

Samantha is released under the MIT License. See LICENSE for details.

šŸ™ Acknowledgments

  • The Model Context Protocol team for the MCP specification
  • Streamlit for the dashboard framework
  • spaCy for NLP capabilities

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured