reading-companion
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@reading-companionInterview me for my reading goals"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Reading Companion
A 4-stage reading companion that helps you set goals, discover books, track progress, and deepen learning through reflection.
Works as an MCP (Model Context Protocol) server integrated with Claude Desktop.
The 4 Stages
┌──────────────┐ ┌──────────────┐ ┌──────────────┐
│ STAGE 1 │ │ STAGE 2 │ │ STAGE 3 │
│ Interviewer │ ──▶ │ Context │ ──▶ │ Syllabus │
│ │ │ Builder │ │ Builder │
│ "Who are you │ │ "Extract │ │ "Build your │
│ as a reader"│ │ patterns" │ │ book stacks"│
└──────────────┘ └──────────────┘ └──────────────┘
│ │
│ ┌──────────────┐ │
└────────────▶ │ STAGE 4 │ ◀──────────┘
│ Reflection │
│ Partner │
│ │
│ "What did │
│ you learn?" │
└──────────────┘Interviewer - Builds your reading profile through conversation
Context Builder - Extracts deeper patterns from your profile
Syllabus Builder - Creates curated book stacks for each domain
Reflection Partner - Helps process books and track growth
Installation
Prerequisites
Python 3.10+
uv (Python package manager)
Claude Desktop
Setup
# Clone the repo
git clone https://github.com/aby0/reading-companion
cd reading-companion
# Install dependencies
uv syncConfigure Claude Desktop
Add to your Claude Desktop config file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"reading-companion": {
"command": "uv",
"args": ["--directory", "/path/to/reading-companion", "run", "reading-companion"]
}
}
}Replace /path/to/reading-companion with the actual path where you cloned the repo.
Restart Claude Desktop. You should see "Reading Companion" in the MCP servers list (hammer icon).
Usage
Initial Setup (Do Once)
Step 1: Run the Interview
You: "Interview me for my reading goals"Claude will ask about your goals, preferences, and context. At the end, your profile is saved.
Step 2: Extract Context (Optional)
You: "Analyze my reading profile"Claude extracts deeper patterns to improve recommendations.
Step 3: Build Your Book Stacks
You: "Build me a reading stack for classic literature"Get curated book recommendations for each domain.
Ongoing Use
Log a completed book:
You: "I just finished Anna Karenina by Tolstoy"Reflect on a book:
You: "I want to reflect on Anna Karenina"Check progress:
You: "How's my reading progress?"Get next recommendation:
You: "What should I read next?"Add a book manually:
You: "Add 'War and Peace' to my classic lit stack"Available Tools
Stage 1: Interviewer
Tool | Description |
| Begin the reading goal interview |
| Save interview results as profile |
| View current profile |
Stage 2: Context Builder
Tool | Description |
| Analyze profile for deeper patterns |
| Save extracted features |
Stage 3: Syllabus Builder
Tool | Description |
| Generate recommendations for a domain |
| Save generated book stack |
| View all book stacks |
| Get next unread book |
| Manually add a book |
Stage 4: Reflection
Tool | Description |
| Quick log a completed book |
| Begin deep reflection session |
| Save reflection insights |
| View reading history |
| Get progress summary |
Author & Pattern Analysis
Tool | Description |
| Analyze your reading history for patterns |
| View profile for an author you've read |
| Add style notes about an author |
| List your top authors by affinity |
| Link related books together |
| Find books connected to one you've read |
Data Storage
All your reading data is stored in ~/reading-companion-data/ (separate from the code):
~/reading-companion-data/
├── profile.md # Your profile (human-readable)
├── profile.json # Profile data (system)
├── bookstacks.json # All stacks data (system)
├── authors.json # Author tracking (system)
├── patterns.json # Reading patterns (system)
├── connections.json # Book connections (system)
│
├── bookstacks/ # Book recommendations
│ ├── _index.md # Overview of all stacks
│ ├── classic_lit.md # One file per domain
│ └── neuroscience.md
│
├── progress/ # Progress tracking
│ ├── _current.md # Current status with progress bars
│ ├── _insights.md # Reading pattern insights
│ └── reading_log.json # Structured log (system)
│
├── authors/ # Author profiles
│ ├── _index.md # All authors by affinity
│ ├── leo-tolstoy.md # One file per author
│ └── james-clear.md
│
└── reflections/ # Book reflections
├── _index.md # Index of all books read
├── anna-karenina.md # One file per book
└── atomic-habits.mdKey feature: All .md files are human-readable and can be opened in VS Code, Obsidian, or any text editor.
Customization
Prompts
The prompts that guide each stage are in the reading_companion/prompts/ directory:
interviewer.md- How interviews are conductedcontext_builder.md- How profiles are analyzedsyllabus_builder.md- How books are curatedreflection.md- How reflections are guided
Feel free to customize these to match your preferences.
Domains
You can have any reading domains you want - they're not hardcoded. During the interview, define whatever areas interest you:
Classic Literature
Science Fiction
Neuroscience
Philosophy
Engineering
History
Whatever you're curious about!
Principles
Intentional over random - Every book serves a purpose
Learning over consuming - Reflection matters as much as reading
Progress over perfection - Steady beats ambitious
Personal over popular - What fits YOU, not bestseller lists
Troubleshooting
"Reading Companion not appearing in Claude Desktop"
Check that the path in
claude_desktop_config.jsonis correctRestart Claude Desktop
Check the MCP logs for errors
"No profile found"
Run
start_interviewfirst to create your profile
"Domain not found"
Check your domain ID matches what's in your profile
Use
get_profileto see available domains
Development
To run the server directly for testing:
uv run reading-companionTo test with the MCP inspector:
npx @modelcontextprotocol/inspector uv run reading-companionLicense
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/aby0/reading-companion'
If you have feedback or need assistance with the MCP directory API, please join our Discord server