
from typing import Optional, Dict
from pydantic import (
    Field,
    model_validator
)
from src.utils.logsetup import logger

from src.agent import BaseAgent
from src.llm import LLM
from src.schema.message import Message, ToolCall
from src.prompt.toolactor import TOOLACTORPROMPT

class ToolActorAgent(BaseAgent):
    """ToolActor agent to synthetic tool observations."""
    name: str = "ToolActorAgent"
    description: Optional[str] = "ToolActor agent to synthetic tool observations."

    toolactor_llm: Optional[LLM] = Field(
        default=None,
        description="LLM for toolactor"
    )

    @model_validator(mode="after")
    def initialize_agent(self) -> "ToolActorAgent":
        try:
            self.toolactor_llm = LLM(config_name="toolactor")
            logger.info(f"Successfully initialized ToolActorAgent, model: {self.toolactor_llm.model}")
        except Exception as e:
            logger.warning(f"Cannot initialize ToolActorAgent,  error: {e}, using default LLM")
            self.toolactor_llm = self.llm

    async def run(
        self,
        reasoning: str,
        tool_call: ToolCall,
        tool_function: Optional[Dict] = None,
        gold_answer: Optional[str] = None,
    ):
        """Perform tool observation synthesis."""
        message = [
            Message.user_message(
                TOOLACTORPROMPT.format(
                    reasoning=reasoning,
                    tool_call=str(tool_call),
                    tool_function=str(tool_function),
                    gold_answer=gold_answer if gold_answer else "N/A"
                )
            )
        ]
        response = await self.toolactor_llm.ask(
            message
        )
        return response