import json
import traceback
from typing import List
import logger, prompt, utils
from agent.base import BaseAgent
from pydantic import model_validator
from prompt.summary import SUMMARY_PROMPT, ANSWER_PROMPT
from schema import Plan, Subtask, TaskResult,AttemptDetail
from utils import parse_code, parse_res

class SummaryAgent(BaseAgent):
    """负责对任务进行总结的 Agent"""

    name: str = "SummaryAgent"
    description: str = (
        "负责对任务进行总结的 Agent"
    )


    # def act(self, plan: Plan, summary_type: str = "report",remove_fields: List[str] = ["dependent_task_ids","suggested_next_steps","should_retry","parent_task_id","current_task"]) -> str:
    def act(self, plan: Plan, summary_type: str = "report",remove_fields: List[str] = ["code"]) -> str:
        """
        对任务进行总结

        :param requirement: 原始需求
        :param plan: 任务计划
        :param summary_type: 总结类型，"report" 为项目总结报告，"answer" 为直接回答用户问题
        :return: 总结内容
        """
        from utils import remove_code_recursive
        try:
            # 将 Plan 转为字典以便处理，避免修改原始对象
            plan_dict = plan.model_dump()
            for field in remove_fields:
                remove_code_recursive(plan_dict, field_name=field)  # 移除指定字段，避免总结中包含大量代码
            
            # 格式化 plan 内容
            plan_str = json.dumps(plan_dict, indent=2, ensure_ascii=False)
            
            summary_prompt = "以下是本次任务的执行详情：\n" + plan_str
            
            # 根据 summary_type 选择 Prompt
            if summary_type == "answer":
                system_prompt_content = ANSWER_PROMPT
                log_msg = "【任务总结】开始生成回答..."
                success_msg = "【任务总结】回答生成成功。"
            else:
                system_prompt_content = SUMMARY_PROMPT
                log_msg = "【任务总结】开始生成项目报告..."
                success_msg = "【任务总结】项目报告生成成功。"

            logger.info(log_msg)
            response = self.llm.ask(
                messages=[
                    {"role": "system", "content": system_prompt_content},
                    {"role": "user", "content": summary_prompt},
                ]
            )
            summary = response.choices[0].message.content
            logger.success(success_msg)
            return summary
        except Exception as e:
            logger.error(f"【任务总结】生成总结时出错：{str(e)}")
            traceback.print_exc()
            return "总结生成失败。"