Spaces:
Running
Running
File size: 4,189 Bytes
4d1849f |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 |
import os
import json
import logging
import asyncio
import traceback
from typing import List
logger = logging.getLogger(__name__)
# β
Define Knowledge Storage Path
KNOWLEDGE_FILE = os.path.expanduser("~/zotheos_public/zotheos_knowledge.json")
class KnowledgeCore:
"""π Public Version of Knowledge Core (Simplified Storage and Retrieval)"""
def __init__(self):
"""β
Initialize Knowledge Storage."""
self.knowledge_store = {}
self.load_knowledge()
def load_knowledge(self):
"""β
Load Knowledge from JSON."""
try:
if os.path.exists(KNOWLEDGE_FILE):
with open(KNOWLEDGE_FILE, "r", encoding="utf-8") as file:
self.knowledge_store = json.load(file)
logger.info(f"β
Knowledge loaded from {KNOWLEDGE_FILE}")
else:
self.knowledge_store = {}
logger.info(f"β
Created new knowledge store at {KNOWLEDGE_FILE}")
except Exception as e:
logger.warning(f"β οΈ Error loading knowledge: {e}")
self.knowledge_store = {}
def save_knowledge(self):
"""β
Save Knowledge to JSON."""
try:
with open(KNOWLEDGE_FILE, "w", encoding="utf-8") as file:
json.dump(self.knowledge_store, file, indent=4)
logger.info(f"β
Knowledge saved to {KNOWLEDGE_FILE}")
except Exception as e:
logger.warning(f"β οΈ Error saving knowledge: {e}")
async def update(self, new_knowledge: str, category: str = "general") -> bool:
"""β
Add New Knowledge to the Store."""
try:
knowledge_id = str(len(self.knowledge_store) + 1)
self.knowledge_store[knowledge_id] = {
'content': new_knowledge,
'category': category
}
self.save_knowledge()
logger.info(f"β
Knowledge added with ID {knowledge_id}")
return True
except Exception as e:
logger.error(f"β Error updating knowledge: {traceback.format_exc()}")
return False
async def retrieve(self, query: str, n_results: int = 5) -> List[dict]:
"""π Retrieve Relevant Knowledge Based on Simple Keyword Match."""
try:
matches = []
for knowledge_id, data in self.knowledge_store.items():
if query.lower() in data['content'].lower():
matches.append({
'id': knowledge_id,
'content': data['content'],
'category': data['category']
})
if len(matches) >= n_results:
break
logger.info(f"β
Retrieved {len(matches)} matches for query '{query}'")
return matches
except Exception as e:
logger.error(f"β Error retrieving knowledge: {traceback.format_exc()}")
return []
async def reset(self) -> bool:
"""ποΈ Reset Knowledge Store (Delete All Stored Data)."""
try:
self.knowledge_store = {}
self.save_knowledge()
logger.info("β
Knowledge store reset successfully.")
return True
except Exception as e:
logger.error(f"β Error resetting knowledge store: {traceback.format_exc()}")
return False
async def delete_knowledge(self, knowledge_id: str) -> bool:
"""ποΈ Delete Specific Knowledge Entry by ID."""
try:
if knowledge_id in self.knowledge_store:
del self.knowledge_store[knowledge_id]
self.save_knowledge()
logger.info(f"β
Deleted knowledge ID: {knowledge_id}")
return True
else:
logger.warning(f"β οΈ Knowledge ID {knowledge_id} not found.")
return False
except Exception as e:
logger.error(f"β Error deleting knowledge ID {knowledge_id}: {traceback.format_exc()}")
return False
|