from src.tools.tool_can_use.base_tool import BaseTool from src.chat.person_info.person_info import person_info_manager from src.common.logger_manager import get_logger import time logger = get_logger("rename_person_tool") class RenamePersonTool(BaseTool): name = "rename_person" description = ( "这个工具可以改变用户的昵称。你可以选择改变对他人的称呼。你想给人改名,叫别人别的称呼,需要调用这个工具。" ) parameters = { "type": "object", "properties": { "person_name": {"type": "string", "description": "需要重新取名的用户的当前昵称"}, "message_content": { "type": "string", "description": "当前的聊天内容或特定要求,用于提供取名建议的上下文,尽可能详细。", }, }, "required": ["person_name"], } async def execute(self, function_args: dict, message_txt=""): """ 执行取名工具逻辑 Args: function_args (dict): 包含 'person_name' 和可选 'message_content' 的字典 message_txt (str): 原始消息文本 (这里未使用,因为 message_content 更明确) Returns: dict: 包含执行结果的字典 """ person_name_to_find = function_args.get("person_name") request_context = function_args.get("message_content", "") # 如果没有提供,则为空字符串 if not person_name_to_find: return {"name": self.name, "content": "错误:必须提供需要重命名的用户昵称 (person_name)。"} try: # 1. 根据昵称查找用户信息 logger.debug(f"尝试根据昵称 '{person_name_to_find}' 查找用户...") person_info = await person_info_manager.get_person_info_by_name(person_name_to_find) if not person_info: logger.info(f"未找到昵称为 '{person_name_to_find}' 的用户。") return { "name": self.name, "content": f"找不到昵称为 '{person_name_to_find}' 的用户。请确保输入的是我之前为该用户取的昵称。", } person_id = person_info.get("person_id") user_nickname = person_info.get("nickname") # 这是用户原始昵称 user_cardname = person_info.get("user_cardname") user_avatar = person_info.get("user_avatar") if not person_id: logger.error(f"找到了用户 '{person_name_to_find}' 但无法获取 person_id") return {"name": self.name, "content": f"找到了用户 '{person_name_to_find}' 但获取内部ID时出错。"} # 2. 调用 qv_person_name 进行取名 logger.debug( f"为用户 {person_id} (原昵称: {person_name_to_find}) 调用 qv_person_name,请求上下文: '{request_context}'" ) result = await person_info_manager.qv_person_name( person_id=person_id, user_nickname=user_nickname, user_cardname=user_cardname, user_avatar=user_avatar, request=request_context, ) # 3. 处理结果 if result and result.get("nickname"): new_name = result["nickname"] # reason = result.get("reason", "未提供理由") logger.info(f"成功为用户 {person_id} 取了新昵称: {new_name}") content = f"已成功将用户 {person_name_to_find} 的备注名更新为 {new_name}" logger.info(content) return {"type": "info", "id": f"rename_success_{time.time()}", "content": content} else: logger.warning(f"为用户 {person_id} 调用 qv_person_name 后未能成功获取新昵称。") # 尝试从内存中获取可能已经更新的名字 current_name = await person_info_manager.get_value(person_id, "person_name") if current_name and current_name != person_name_to_find: return { "name": self.name, "content": f"尝试取新昵称时遇到一点小问题,但我已经将 '{person_name_to_find}' 的昵称更新为 '{current_name}' 了。", } else: return { "name": self.name, "content": f"尝试为 '{person_name_to_find}' 取新昵称时遇到了问题,未能成功生成。可能需要稍后再试。", } except Exception as e: error_msg = f"重命名失败: {str(e)}" logger.error(error_msg, exc_info=True) return {"type": "info_error", "id": f"rename_error_{time.time()}", "content": error_msg} # 注册工具 # register_tool(RenamePersonTool)