Files
Mofox-Core/plugins/memory_graph_plugin/plugin.py
2025-11-07 04:39:35 +00:00

86 lines
2.7 KiB
Python

"""
记忆系统插件主类
"""
from typing import ClassVar
from src.common.logger import get_logger
from src.plugin_system import BasePlugin, register_plugin
logger = get_logger("memory_graph_plugin")
# 用于存储后台任务引用
_background_tasks = set()
@register_plugin
class MemoryGraphPlugin(BasePlugin):
"""记忆图系统插件"""
plugin_name = "memory_graph_plugin"
enable_plugin = True
dependencies: ClassVar = []
python_dependencies: ClassVar = []
config_file_name = "config.toml"
config_schema: ClassVar = {}
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
logger.info(f"{self.log_prefix} 插件已加载")
def get_plugin_components(self):
"""返回插件组件列表"""
from src.memory_graph.plugin_tools.memory_plugin_tools import (
CreateMemoryTool,
LinkMemoriesTool,
SearchMemoriesTool,
)
components = []
# 添加工具组件
for tool_class in [CreateMemoryTool, LinkMemoriesTool, SearchMemoriesTool]:
tool_info = tool_class.get_tool_info()
components.append((tool_info, tool_class))
return components
async def on_plugin_loaded(self):
"""插件加载后的回调"""
try:
from src.memory_graph.manager_singleton import initialize_memory_manager
logger.info(f"{self.log_prefix} 正在初始化记忆系统...")
await initialize_memory_manager()
logger.info(f"{self.log_prefix} ✅ 记忆系统初始化成功")
except Exception as e:
logger.error(f"{self.log_prefix} 初始化记忆系统失败: {e}", exc_info=True)
raise
def on_unload(self):
"""插件卸载时的回调"""
try:
import asyncio
from src.memory_graph.manager_singleton import shutdown_memory_manager
logger.info(f"{self.log_prefix} 正在关闭记忆系统...")
# 在事件循环中运行异步关闭
loop = asyncio.get_event_loop()
if loop.is_running():
# 如果循环正在运行,创建任务
task = asyncio.create_task(shutdown_memory_manager())
# 存储引用以防止任务被垃圾回收
_background_tasks.add(task)
task.add_done_callback(_background_tasks.discard)
else:
# 如果循环未运行,直接运行
loop.run_until_complete(shutdown_memory_manager())
logger.info(f"{self.log_prefix} ✅ 记忆系统已关闭")
except Exception as e:
logger.error(f"{self.log_prefix} 关闭记忆系统时出错: {e}", exc_info=True)