Compare commits

...

2 Commits

Author SHA1 Message Date
1af194f05d optimize mcp
All checks were successful
Build and Push Agent Docker Image / build (push) Successful in 1m6s
2025-12-18 18:37:30 +01:00
46171a9a2b cite sources 2025-12-18 18:28:35 +01:00
2 changed files with 10 additions and 5 deletions

View File

@@ -59,11 +59,10 @@ def embed(text, input_type):
assert resp.embeddings.float_ is not None
return resp.embeddings.float_[0]
def search(query, roles: list[str], limit: int = 5) -> list[dict]:
def search(query, roles: list[str], limit: int = 3, max_content_length: int = 1500) -> list[dict]:
query_embedding = embed(query, 'search_query')
if not roles:
# No roles = no results
return []
rows = conn.execute(
@@ -71,7 +70,13 @@ def search(query, roles: list[str], limit: int = 5) -> list[dict]:
(roles, query_embedding, limit)
).fetchall()
return [{'key': row['key'], 'content': row['content']} for row in rows]
docs = []
for row in rows:
content = row['content'] or ''
if len(content) > max_content_length:
content = content[:max_content_length] + '...[truncated, use get_document_page for full text]'
docs.append({'key': row['key'], 'content': content})
return docs
@mcp.tool
def get_cave_location(cave: str, state: str, county: str) -> list[dict]:

View File

@@ -64,13 +64,13 @@ def check_mcp_available(url: str, timeout: float = 5.0) -> bool:
AGENT_INSTRUCTIONS = """Caving assistant. Help with exploration, safety, surveying, locations, geology, equipment, history, conservation.
Rules:
1. Cite sources when possible.
1. ALWAYS cite sources at the end of every reply. Use the 'key' from search results (e.g., "Source: vpi/trog/2021-trog.pdf/page-19.pdf").
2. Say when uncertain. Never hallucinate.
3. Be safety-conscious.
4. Can create ascii diagrams/maps.
5. Be direct—no sycophantic phrases.
6. Keep responses concise.
7. Use tools sparingly—one search usually suffices. Answer from your knowledge when possible."""
7. Use tools sparingly—one search usually suffices."""
def create_agent(user_roles: list[str] | None = None):