Local Memory Hub MCP Server with stdio transport for ZenCoder and MCP clients
Project description
Memory Hub MCP Server (UV/UVX)
A local memory hub for AI agents with MCP integration, designed for ZenCoder and other MCP clients using stdio transport.
Quick Start with UVX
Installation & Usage
# Install and run directly with uvx
uvx memory-hub-mcp
# Or install locally first
uv pip install memory-hub-mcp
memory-hub-mcp
For ZenCoder Integration
In ZenCoder's custom MCP server configuration, you must now provide the URLs for the dependent services (Qdrant and LM Studio).
Command: uvx
Arguments:
[
"memory-hub-mcp",
"--qdrant-url",
"http://<ip_address_of_qdrant>:6333",
"--lm-studio-url",
"http://<ip_address_of_lm_studio>:1234/v1"
]
Note: Replace
<ip_address_...>with the actual IP addresses where your services are running. If they are on the same machine, the IP will be the same for both.
Development Setup
# Clone and setup
git clone <your-repo>
cd memory-hub
uv venv
source .venv/bin/activate
uv pip install -e .
# Run in development
memory-hub-mcp --log-level DEBUG --qdrant-url http://localhost:6333 --lm-studio-url http://localhost:1234/v1
Publishing to PyPI
To publish a new version of the package to PyPI:
-
Update the Version: Increment the
versionnumber inpyproject.toml. PyPI does not allow re-uploading the same version.# pyproject.toml [project] name = "memory-hub-mcp" version = "0.1.2" # Increment this
-
Clean and Rebuild: Remove old builds and create the new distributions.
rm -rf dist/ uv build
-
Publish with an API Token:
The recommended way to publish is to use a PyPI API token. You can provide it directly to the command via an environment variable for security.
# Replace <your_pypi_token> with your actual token UV_PUBLISH_TOKEN=<your_pypi_token> uv publish dist/*
Available Tools
- add_memory: Store content with hierarchical metadata (app_id, project_id, ticket_id)
- search_memories: Semantic search with keyword enhancement and LLM synthesis
- get_project_memories: Retrieve ALL memories for a specific app_id/project_id without search queries
- update_memory: Update existing memories with automatic version incrementing
- get_recent_memories: Retrieve memories from the last N hours (perfect for resuming work)
- list_app_ids: List all application IDs
- list_project_ids: List all project IDs
- list_ticket_ids: List all ticket IDs
- list_memory_types: List memory types currently in use (with counts and metadata)
- get_memory_type_guide: Get the recommended memory type conventions
- health_check: Server health status
Configuration
The server expects:
- Qdrant: Vector database running (see docker-compose.yml)
- LM Studio: For embeddings and chat completions
- Environment: Standard .env configuration
Key File & Directory Locations
pyproject.toml: Defines project metadata, dependencies, and thememory-hub-mcpscript entry point.src/memory_hub/: The main Python package source code.src/memory_hub/cli.py: The command-line interface logic that launches the server.src/memory_hub/mcp_server.py: Corestdioserver implementation and tool registration.src/memory_hub/core/handlers/: Contains the implementation for each MCP tool (e.g.,add_memory,search_memories).src/memory_hub/core/services.py: Handles communication with external services like Qdrant and LM Studio.src/memory_hub/core/models.py: Pydantic models defining the data structures used throughout the application.docker-compose.yml: Defines the Qdrant service dependency.
Architecture
- stdio transport: Direct MCP protocol communication
- No HTTP dependencies: Lightweight, focused on MCP clients
- Hierarchical memory: Flexible app/project/ticket organization
- Hybrid search: Vector similarity + keyword matching + LLM synthesis
- Version management: Automatic versioning for memory updates
- Time-based retrieval: Query recent memories by hours
Agent Usage Guide
Saving Agent Progress
# Save initial work
add_memory(
content="Implemented user authentication with JWT tokens...",
metadata={
"app_id": "eatzos",
"project_id": "next",
"type": "feature_implementation"
}
)
# Update existing memory
update_memory(
app_id="eatzos",
project_id="next",
memory_type="feature_implementation",
new_content="Completed authentication with JWT tokens and added refresh token logic..."
)
Resuming Agent Work
# Get ALL context for a project (no search guessing!)
get_project_memories(
app_id="eatzos",
project_id="next",
limit=50
)
# See what changed recently
get_recent_memories(
app_id="eatzos",
hours=24,
include_summary=True
)
Differences from HTTP Version
This UV/UVX version:
- ✅ Uses stdio transport (ZenCoder compatible)
- ✅ No FastAPI dependencies
- ✅ Lightweight packaging
- ✅ Direct MCP protocol
- ❌ No web interface
- ❌ No HTTP endpoints
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file memory_hub_mcp-1.7.0.tar.gz.
File metadata
- Download URL: memory_hub_mcp-1.7.0.tar.gz
- Upload date:
- Size: 92.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ad36fb17b348aa5db05f8d637d32adf8b03c8ff2fb64f8b734be9e9f965f5510
|
|
| MD5 |
658192771d897de86d2cc75610b2adcf
|
|
| BLAKE2b-256 |
8c1090adcf6077c81c84c45d9f3d9289306a74bc640728cc766cc727e70b3cba
|
File details
Details for the file memory_hub_mcp-1.7.0-py3-none-any.whl.
File metadata
- Download URL: memory_hub_mcp-1.7.0-py3-none-any.whl
- Upload date:
- Size: 37.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8485d5d6ce45a20221908f4bcc01159f3ebca24daf503d9c632fe75383271bfa
|
|
| MD5 |
9ed1d8d712934a400ab2fc154a6e3991
|
|
| BLAKE2b-256 |
472b1060f7d61e09ab6ab962e8d0b21a9a50cb9260851e25f5aab4a46c14e6bc
|