forked from Rockachopa/Timmy-time-dashboard
## 1. MCP (Model Context Protocol) Implementation ### Registry (src/mcp/registry.py) - Tool registration with JSON schemas - Dynamic tool discovery - Health tracking per tool - Metrics collection (latency, error rates) - @register_tool decorator for easy registration ### Server (src/mcp/server.py) - MCPServer class implementing MCP protocol - MCPHTTPServer for FastAPI integration - Standard endpoints: list_tools, call_tool, get_schema ### Schemas (src/mcp/schemas/base.py) - create_tool_schema() helper - Common parameter types - Standard return types ### Bootstrap (src/mcp/bootstrap.py) - Automatic tool module loading - Status reporting ## 2. MCP-Compliant Tools (src/tools/) | Tool | Purpose | Category | |------|---------|----------| | web_search | DuckDuckGo search | research | | read_file | File reading | files | | write_file | File writing (confirmation) | files | | list_directory | Directory listing | files | | python | Python code execution | code | | memory_search | Vector memory search | memory | All tools have proper schemas, error handling, and MCP registration. ## 3. Event Bus (src/events/bus.py) - Async publish/subscribe pattern - Pattern matching with wildcards (agent.task.*) - Event history tracking - Concurrent handler execution - Module-level singleton for system-wide use ## 4. Sub-Agents (src/agents/) All agents inherit from BaseAgent with: - Agno Agent integration - MCP tool registry access - Event bus connectivity - Structured logging ### Agent Roster | Agent | Role | Tools | Purpose | |-------|------|-------|---------| | Seer | Research | web_search, read_file, memory_search | Information gathering | | Forge | Code | python, write_file, read_file | Code generation | | Quill | Writing | write_file, read_file, memory_search | Content creation | | Echo | Memory | memory_search, read_file, write_file | Context retrieval | | Helm | Routing | memory_search | Task routing decisions | | Timmy | Orchestrator | All tools | Coordination & user interface | ### Timmy Orchestrator - Analyzes user requests - Routes to appropriate sub-agent - Handles direct queries - Manages swarm coordination - create_timmy_swarm() factory function ## 5. Integration All components wired together: - Tools auto-register on import - Agents connect to event bus - MCP server provides HTTP API - Ready for dashboard integration ## Tests - All 973 existing tests pass - New components tested manually - Import verification successful Next steps: Cascade Router, Self-Upgrade Loop, Dashboard integration
71 lines
2.0 KiB
Python
71 lines
2.0 KiB
Python
"""Memory search tool.
|
|
|
|
MCP-compliant tool for searching Timmy's memory.
|
|
"""
|
|
|
|
import logging
|
|
from typing import Any
|
|
|
|
from mcp.registry import register_tool
|
|
from mcp.schemas.base import create_tool_schema, PARAM_STRING, PARAM_INTEGER, RETURN_STRING
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
MEMORY_SEARCH_SCHEMA = create_tool_schema(
|
|
name="memory_search",
|
|
description="Search Timmy's memory for past conversations, facts, and context. Use when user asks about previous discussions or when you need to recall something from memory.",
|
|
parameters={
|
|
"query": {
|
|
**PARAM_STRING,
|
|
"description": "What to search for in memory",
|
|
},
|
|
"top_k": {
|
|
**PARAM_INTEGER,
|
|
"description": "Number of results to return (1-10)",
|
|
"default": 5,
|
|
"minimum": 1,
|
|
"maximum": 10,
|
|
},
|
|
},
|
|
required=["query"],
|
|
returns=RETURN_STRING,
|
|
)
|
|
|
|
|
|
def memory_search(query: str, top_k: int = 5) -> str:
|
|
"""Search Timmy's memory.
|
|
|
|
Args:
|
|
query: Search query
|
|
top_k: Number of results
|
|
|
|
Returns:
|
|
Relevant memories from past conversations
|
|
"""
|
|
try:
|
|
from timmy.semantic_memory import memory_search as semantic_search
|
|
|
|
results = semantic_search(query, top_k=top_k)
|
|
|
|
if not results:
|
|
return "No relevant memories found."
|
|
|
|
formatted = ["Relevant memories from past conversations:", ""]
|
|
|
|
for i, (content, score) in enumerate(results, 1):
|
|
relevance = "🔥" if score > 0.8 else "⭐" if score > 0.5 else "📄"
|
|
formatted.append(f"{relevance} [{i}] (score: {score:.2f})")
|
|
formatted.append(f" {content[:300]}...")
|
|
formatted.append("")
|
|
|
|
return "\n".join(formatted)
|
|
|
|
except Exception as exc:
|
|
logger.error("Memory search failed: %s", exc)
|
|
return f"Memory search error: {exc}"
|
|
|
|
|
|
# Register with MCP
|
|
register_tool(name="memory_search", schema=MEMORY_SEARCH_SCHEMA, category="memory")(memory_search)
|