A-Modular-Kingdom
Production-ready MCP server providing RAG, hierarchical memory, and 8+ tools for AI agents via the Model Context Protocol.
README
๐ฐ A-Modular-Kingdom
Production-ready MCP server with RAG, memory, and tools
Stop rebuilding the same infrastructure. Connect any AI agent to long-term memory, document retrieval, and 8+ powerful tools through the Model Context Protocol.
The Problem
Building AI agents? You keep reinventing:
- Long-term memory that persists across sessions
- Document retrieval (RAG) for knowledge access
- Tool integration (web search, vision, code execution, browser automation)
Every project starts from scratch. Every agent rebuilds the wheel.
The Solution
A-Modular-Kingdom is the infrastructure layer you're missing:
# Start the MCP server
python src/agent/host.py
Now any agent (Claude Desktop, custom chatbots, multi-agent systems) gets instant access to:
- โ Hierarchical memory (global rules, project context)
- โ 3 RAG implementations (v1/v2/v3) for document search
- โ 8 production-ready tools via MCP protocol
One foundation. Infinite applications.
๐ Table of Contents
- โจ Core Features
- ๐ Quick Start
- ๐ ๏ธ Available Tools
- ๐ RAG System
- ๐ง Memory System
- ๐ฆ Package Installation
- ๐ฏ Integration Examples
- ๐ค Example Applications
- ๐ค Contributing
โจ Core Features
- MCP Protocol - Standard interface for AI tool access
- 3 RAG Versions - Choose your retrieval strategy (FAISS, Qdrant, custom)
- Scoped Memory - Global rules, preferences, project-specific context
- 8+ Tools - Vision, code exec, browser, web search, TTS/STT, and more
- No Vendor Lock-in - Local Ollama models, open-source stack
- Production Ready - Smart reindexing, Unicode support, error handling
๐ Quick Start
Prerequisites
# Required
Python 3.10+
Ollama (for embeddings: ollama pull embeddinggemma)
# Optional
UV package manager (faster than pip)
Installation
# Clone the repository
git clone https://github.com/MasihMoafi/A-Modular-Kingdom.git
cd A-Modular-Kingdom
# Install dependencies
uv sync
# or: pip install -r requirements.txt
# Pull required Ollama model
ollama pull embeddinggemma
Start the MCP Server
# Start host.py MCP server
python src/agent/host.py
Connect Your Agent
Option 1: Claude Desktop
// Add to claude_desktop_config.json
{
"mcpServers": {
"a-modular-kingdom": {
"command": "python",
"args": ["/full/path/to/A-Modular-Kingdom/src/agent/host.py"]
}
}
}
Option 2: Interactive Client
# Use the included chat interface
python src/agent/main.py
Option 3: Custom Integration
# Connect via MCP in your own agent
from mcp import StdioServerParameters
server_params = StdioServerParameters(
command="python",
args=["/path/to/host.py"]
)
# Use with ToolCollection.from_mcp(server_params)
๐ ๏ธ Available Tools
The MCP server exposes these tools:
| Tool | Description | Use Case |
|---|---|---|
query_knowledge_base |
RAG search (v1/v2/v3) | "How does auth work in this codebase?" |
save_memory |
Scoped memory storage | Save global rules or project context |
search_memories |
Semantic memory search | Retrieve past decisions/preferences |
web_search |
DuckDuckGo search | Current events, latest docs |
browser_automation |
Playwright web scraping | Extract text/screenshot from URLs |
code_execute |
Safe Python sandbox | Run code in isolated environment |
analyze_media |
Vision with Ollama | Analyze images/videos |
text_to_speech |
TTS (pyttsx3/kokoro) | Generate audio from text |
speech_to_text |
Whisper STT | Transcribe audio files |
๐ RAG System
Three implementations with different trade-offs:
V1 - Simple & Fast
- Stack: FAISS + BM25
- Speed: <1s
- Use Case: Small projects, quick prototypes
V2 - Production (Recommended)
- Stack: Qdrant + BM25 + CrossEncoder reranking
- Speed: <1s with smart caching
- Use Case: Production apps, large codebases
- Features: Smart reindexing, cloud-ready
V3 - Advanced
- Stack: Custom vector index + BM25 + RRF fusion + LLM reranking
- Speed: 2-3s (LLM reranking overhead)
- Use Case: Research, maximum accuracy
- Features: Contextual retrieval, custom distance metrics
Usage:
# Via MCP tool
query_knowledge_base(
query="How does authentication work?",
version="v2", # or "v1", "v3"
doc_path="./src" # optional
)
Supported Files: .py, .md, .txt, .pdf, .ipynb, .js, .ts
๐ง Memory System
Hierarchical scoped memory with automatic categorization:
Memory Scopes
| Scope | Persistence | Use Case |
|---|---|---|
| Global Rules | Forever, all projects | "Always use type hints" |
| Global Preferences | Forever, all projects | "Prefer dark mode" |
| Global Personas | Forever, all projects | Reusable agent personalities |
| Project Context | Current project | Architecture decisions, tech stack |
| Project Sessions | Temporary | Current task, recent changes |
Usage
# Save with explicit scope
save_memory(content="Always validate user input", scope="global_rules")
# Or use prefix shortcuts
save_memory(content="#global:rule:Never use eval()")
save_memory(content="#project:context:Uses FastAPI backend")
# Auto-inference from keywords
save_memory(content="User prefers Python 3.12") # โ global_preferences
# Search with priority (global โ project)
search_memories(query="coding standards", top_k=5)
Storage: ~/.modular_kingdom/memories/ (global) + project-specific folders
๐ฆ Package Installation
The MCP server can also be installed as a standalone package:
# Install with sentence-transformers (no Ollama required)
pip install rag-mem[local]
# Set embedding provider (add to your shell profile or script)
export MEMORY_MCP_EMBED_PROVIDER=sentence-transformers
export MEMORY_MCP_EMBED_MODEL=all-MiniLM-L6-v2
Python API:
from memory_mcp.config import Settings
from memory_mcp.rag import RAGPipeline
from memory_mcp.memory import MemoryStore
# RAG - index and search any codebase
pipeline = RAGPipeline(Settings(), document_paths=["./src"])
pipeline.index()
results = pipeline.search("how does authentication work")
# Memory - persistent storage across sessions
store = MemoryStore(Settings())
store.add("User prefers dark mode")
results = store.search("preferences")
CLI Usage:
memory-mcp init # Initialize config
memory-mcp serve --docs ./documents # Start MCP server
memory-mcp index ./path/to/files # Index documents
Alternative: Use Ollama (local, private)
pip install rag-mem
ollama pull nomic-embed-text
# No env vars needed - Ollama is the default
Package Size: 58KB code (note: ~2GB dependencies with PyTorch)
๐ฏ Integration Examples
Claude Desktop
Already using Claude Code? Add A-Modular-Kingdom tools:
{
"mcpServers": {
"a-modular-kingdom": {
"command": "python",
"args": ["/path/to/src/agent/host.py"]
}
}
}
Now Claude has access to your codebase RAG, persistent memory, and all tools.
Gemini CLI
// gemini-extension.json
{
"mcpServers": {
"unified_knowledge_agent": {
"command": "python",
"args": ["/path/to/src/agent/host.py"]
}
}
}
Custom Agent
from smolagents import ToolCallingAgent, ToolCollection
from mcp import StdioServerParameters
# Connect to MCP server
params = StdioServerParameters(
command="python",
args=["/path/to/host.py"]
)
with ToolCollection.from_mcp(params) as tools:
agent = ToolCallingAgent(tools=list(tools.tools))
result = agent.run("Search the codebase for auth logic")
๐ค Example Applications
This repository includes example multi-agent systems built on the foundation:
Council Chamber (Hierarchical)
- 3-tier agent hierarchy (Queen โ Teacher โ Code Agent)
- Validation loops and task delegation
- Uses ACP SDK + smolagents
- Location:
multiagents/council_chamber/
Note: These are demonstration applications, not the core product. The foundation (host.py) is the main offering.
๐๏ธ Architecture
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ Your AI Application โ
โ (Agents, Chatbots, Workflows) โ
โโโโโโโโโโโโโโฌโโโโโโโโโโโโโโโโโโโโโโโโโ
โ MCP Protocol
โโโโโโโโโโโโโโผโโโโโโโโโโโโโโโโโโโโโโโโโ
โ A-Modular-Kingdom โ
โ โโโโโโโโโโโ โโโโโโโโโโโ โโโโโโโโโโโ
โ โ RAG โ โ Memory โ โ Tools โโ
โ โ V1/V2/V3โ โ Scoped โ โ 8+ โโ
โ โโโโโโโโโโโ โโโโโโโโโโโ โโโโโโโโโโโ
โ host.py (MCP Server) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
๐งช Testing & Performance
Run Tests
# Run all tests
pytest tests/ -v
# Run specific test suites
pytest tests/test_rag_v2.py -v
pytest tests/test_rag_v3.py -v
pytest tests/test_memory_global.py -v
# Run benchmarks
python tests/benchmark_rag.py
Performance
Benchmark Results (GPU/CUDA):
| Version | Docs | Cold Start | Warm Query |
|---|---|---|---|
| V2 | 100 | 26.8s | 0.31s |
| V3 | 100 | 13.9s | 0.02s (15x faster!) |
Key Features:
- โ GPU acceleration (CUDA) for embeddings and reranking
- โ Smart caching (warm queries <0.5s)
- โ Tested with .py, .md, .txt, .ipynb files
- โ Global memory access from any directory
See detailed benchmarks: docs/RAG_PERFORMANCE.md
Docker Testing
Package verified to work in isolation:
docker build -f Dockerfile.test -t rag-mem-test .
docker run --rm rag-mem-test
๐ค Contributing
Contributions welcome! Focus areas:
- Additional RAG strategies - New retrieval techniques
- New tool integrations - Expand MCP tool offerings
- Performance optimizations - Speed improvements
- Documentation improvements - Tutorials, examples
Development Setup
# Fork and clone
git clone https://github.com/MasihMoafi/A-Modular-Kingdom.git
cd A-Modular-Kingdom
# Create branch
git checkout -b feature/your-feature
# Install dev dependencies
uv sync
# Make changes and test
pytest tests/
# Commit with descriptive message
git commit -m "feat: add new tool"
# Push and create PR
git push origin feature/your-feature
๐ License
MIT License - See LICENSE for details
Links
- Medium Article: https://medium.com/@masihmoafi12/a-modular-kingdom-fcaa69a6c1f0
- Demo Video: https://www.youtube.com/watch?v=hWoQnAr6R_E
- PyPI Package: rag-mem
A-Modular-Kingdom: The infrastructure layer AI agents deserve ๐ฐ
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.