Promptbook MCP
A server that stores and semantically searches AI prompts via RAG, enabling developers to reuse prompts from AI coding assistants.
README
π€ Promptbook MCP
Your personal cookbook for AI prompts with RAG-powered semantic search
β¨ What is this?
Promptbook MCP is a plug-and-play server that helps developers who use AI coding assistants (like GitHub Copilot, Claude, etc.) to:
- π Store prompts from your AI sessions automatically
- π Search prompts by meaning, not just keywords (RAG-powered)
- π€ Access your prompt library from any MCP-compatible tool
- π Organize prompts by category (refactoring, testing, debugging, etc.)
Perfect for: Developers who reuse AI prompts and want a searchable knowledge base.
π Quick Start
Get running in 30 seconds:
Option 1: Automated Setup (Recommended)
git clone https://github.com/isaacpalomero/promptbook-mcp.git
cd promptbook-mcp
./setup.sh
That's it! π
Option 2: Docker
git clone https://github.com/isaacpalomero/promptbook-mcp.git
cd promptbook-mcp
docker-compose up -d
Done! Your server is running.
π‘ Use Cases
Problem: You asked ChatGPT/Copilot the perfect prompt for refactoring last week. Now you can't find it.
Solution: Promptbook MCP auto-saves and indexes all your prompts.
# Later, search by meaning
search_prompts("refactor typescript to use dependency injection")
β Returns your exact prompt from last week
Real Examples
- Refactoring patterns - Store your best "clean code" prompts
- Testing strategies - Find that perfect test structure prompt
- Debugging workflows - Access proven debugging prompts
- Code review - Reuse comprehensive review prompts
π¦ Installation
Prerequisites
- Python 3.9+ OR Docker
- 2GB RAM minimum
- macOS, Linux, or Windows
Detailed Setup
Automated Setup (Recommended)
# Clone repository
git clone https://github.com/isaacpalomero/promptbook-mcp.git
cd promptbook-mcp
# Run setup script
chmod +x setup.sh
./setup.sh
# Activate virtual environment
source .venv/bin/activate # Windows: .venv\Scripts\activate
# Start server
python mcp_server.py
Docker Method
# Clone repository
git clone https://github.com/isaacpalomero/promptbook-mcp.git
cd promptbook-mcp
# Copy environment file
cp .env.example .env
# Start services
docker-compose up -d
# Verify
docker-compose logs
Manual Setup
# Create virtual environment
python3 -m venv .venv
source .venv/bin/activate # Windows: .venv\Scripts\activate
# Install dependencies
pip install -r requirements.txt
# Create directories
mkdir -p prompts sessions
# Index existing prompts (if any)
python prompt_rag.py --index
# Start server
python mcp_server.py
π― Features
1. Semantic Search (RAG)
Find prompts by meaning, not exact words:
search_prompts("how to add unit tests")
β Finds prompts about "testing", "jest", "pytest", etc.
2. Auto-Organization
Drop AI session files β Auto-categorized and indexed:
sessions/
βββ copilot-session-abc123.md β Auto-processed into:
βββ prompts/refactoring/prompt1.md
βββ prompts/testing/prompt2.md
βββ Updated RAG index
3. Multi-Provider Embeddings
Choose your embedding backend:
- Sentence-Transformers (default, local, CPU)
- LMStudio (GPU-accelerated, better quality)
# Use local embeddings (default)
EMBEDDING_PROVIDER=sentence-transformer
# Or use LMStudio
EMBEDDING_PROVIDER=lmstudio
LMSTUDIO_URL=http://localhost:1234
4. MCP Tools (13 Available)
Access via any MCP client:
| Tool | Description |
|---|---|
search_prompts |
Semantic search by meaning |
create_prompt |
Add new prompt directly |
update_prompt |
Modify existing prompt |
delete_prompt |
Remove prompt safely |
get_prompt_by_file |
Get full content |
list_prompts_by_category |
Browse by category |
find_similar_prompts |
Find related prompts |
get_library_stats |
View statistics |
index_prompts |
Rebuild search index |
organize_session |
Process AI session file |
get_prompt_index |
View full metadata index |
Available categories:
refactoringtestingdebuggingimplementationdocumentationcode-reviewgeneral
π MCP Client Setup
Claude Desktop
-
Open Claude config file:
# macOS ~/Library/Application Support/Claude/claude_desktop_config.json # Windows %APPDATA%\Claude\claude_desktop_config.json -
Add Promptbook MCP server:
{ "mcpServers": { "promptbook": { "command": "python", "args": ["/path/to/promptbook-mcp/mcp_server.py"] } } } -
Restart Claude Desktop
Other MCP Clients
Any MCP-compatible client can connect using the same pattern. See MCP Protocol docs for details.
π Documentation
- Setup Guide - Detailed installation steps
- Deployment Options - Docker, local, and production setups
- Embeddings Guide - Configure RAG providers
- Contributing - How to contribute
- Changelog - Version history
π¨βπ» For Developers
βοΈ Configuration
All runtime settings are centralized in config.py and exposed through an immutable Config dataclass. The server loads environment variables once at startup.
Environment Variables
| Variable | Description | Default |
|---|---|---|
PROMPTS_DIR |
Root folder for categorized prompts | ./prompts |
SESSIONS_DIR |
Directory watched for exported sessions | ./sessions |
VECTOR_DB_DIR |
Persistent ChromaDB path | <PROMPTS_DIR>/.vectordb |
EMBEDDING_PROVIDER |
sentence-transformer or lmstudio |
sentence-transformer |
EMBEDDING_MODEL |
Sentence Transformers model name | all-MiniLM-L6-v2 |
LMSTUDIO_URL / LMSTUDIO_MODEL |
LMStudio endpoint + model | http://localhost:1234 / nomic-embed-text |
LMSTUDIO_DIMENSION |
Expected LMStudio embedding size | 768 |
CHUNK_SIZE / CHUNK_OVERLAP |
Prompt chunking parameters | 500 / 100 |
ENABLE_RAG |
Toggle RAG initialization | true |
AUTO_REINDEX_INTERVAL |
Seconds between auto-index checks | 30 |
LOG_LEVEL |
Python logging level | INFO |
Configuration file:
# Copy example
cp .env.example .env
# Edit settings
vim .env
Access config anywhere in code:
from config import CONFIG
print(CONFIG.prompts_dir) # Validated Path object
print(CONFIG.embedding_provider) # Type-safe enum
π§ͺ Testing & Quality
We enforce strict quality gates:
# Run all tests
pytest
# Run with coverage
pytest --cov=. --cov-report=html
# Run only unit tests
pytest tests/unit/
# Run only integration tests
pytest tests/integration/
# Style check
flake8 --max-line-length=100
# Type check
mypy --strict mcp_server.py prompt_rag.py prompt_organizer.py
Quality Standards
- Test Coverage: Minimum 80%
- Type Safety:
mypy --strictmust pass - Code Style: Flake8 compliant
- CI Pipeline: All checks run on Python 3.9-3.12
A GitHub Actions workflow (.github/workflows/ci.yml) runs these checks automatically.
π³ Docker Advanced
Multi-Stage Build
The Dockerfile uses a multi-stage build for optimized image size:
# Stage 1: Builder (installs dependencies)
FROM python:3.11-slim as builder
# Stage 2: Runtime (slim final image)
FROM python:3.11-slim
COPY --from=builder /app/.venv /app/.venv
Result: Final image < 800 MB
Health Checks
Docker includes automatic health monitoring:
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
CMD python -m prompt_rag --health || exit 1
Volume Mounts
Persist data outside containers:
volumes:
- ./prompts:/app/prompts # Prompt storage
- ./sessions:/app/sessions # Session import
- ./prompts/.vectordb:/app/prompts/.vectordb # RAG database
Building & Running
# Build image
docker build -t promptbook-mcp:latest .
# Run container
docker run --rm -i \
-v "$(pwd)/prompts:/app/prompts" \
-v "$(pwd)/sessions:/app/sessions" \
-e EMBEDDING_PROVIDER=sentence-transformer \
promptbook-mcp:latest
ποΈ Architecture
Components
βββββββββββββββββββββββββββββββββββββββ
β MCP Client (Claude) β
ββββββββββββββββ¬βββββββββββββββββββββββ
β MCP Protocol
ββββββββββββββββΌβββββββββββββββββββββββ
β mcp_server.py β
β - 13 MCP tools β
β - Request routing β
β - Error handling β
ββββββββββββββββ¬βββββββββββββββββββββββ
β
βββββββββ΄βββββββββ
β β
ββββββββΌβββββββ βββββββΌβββββββββ
βprompt_rag.pyβ βprompt_org.py β
β- RAG search β β- Session β
β- Embeddings β β parsing β
β- ChromaDB β β- Auto-org β
βββββββββββββββ ββββββββββββββββ
β β
βββββββββ¬βββββββββ
β
ββββββββββββββββΌβββββββββββββββββββββββ
β prompts/ β
β βββ refactoring/ β
β βββ testing/ β
β βββ debugging/ β
β βββ .vectordb/ β
βββββββββββββββββββββββββββββββββββββββ
Data Flow
- User asks Claude to search prompts
- Claude sends MCP request to
mcp_server.py - Server calls
prompt_rag.pyfor semantic search - RAG queries ChromaDB vector database
- Results returned to Claude with metadata
- User sees relevant prompts instantly
π€ Contributing
We love contributions! π
Quick Start
- Fork the repository
- Create feature branch:
git checkout -b feature/amazing-feature - Make changes and add tests
- Run tests:
pytest - Ensure quality:
flake8 && mypy --strict - Commit:
git commit -m 'feat: add amazing feature' - Push:
git push origin feature/amazing-feature - Open Pull Request
See CONTRIBUTING.md for detailed guidelines.
Commit Convention
We follow Conventional Commits:
feat:New featurefix:Bug fixdocs:Documentation onlystyle:Code style changesrefactor:Code refactoringtest:Test changeschore:Build/tooling changes
π License
This project is licensed under the MIT License - see LICENSE file for details.
π Acknowledgments
- Built with MCP Protocol
- Powered by ChromaDB and Sentence-Transformers
- Inspired by the need for better prompt management in AI-assisted development
π Support
- π Report bugs
- π‘ Request features
- π¬ Discussions
- π Documentation
Made with β€οΈ for the AI development community
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.