from typing import Optional, Dict, List
from pydantic import Field, model_validator
from src.utils.logsetup import logger
from src.agent import BaseAgent
from src.llm import LLM
from src.prompt.code_data_generator import CODE_DATA_GENERATOR_PROMPT
from src.schema.message import Message, Memory, AgentState


class CodeDataGeneratorAgent(BaseAgent):
    """Code data generator agent for creating high-quality coding training data"""
    name: str = "CodeDataGeneratorAgent"
    description: str = "Agent specialized in generating structured code problem solutions for training data"
    
    # No tools needed - pure generation without validation
    tools: Optional[List[Dict]] = Field(
        default_factory=list,
        description="No tools needed for code data generation"
    )
    tool_map: Optional[Dict] = Field(
        default_factory=dict,
        description="Empty tool map for code data generation"
    )

    system_prompt: str = CODE_DATA_GENERATOR_PROMPT
    memory: Memory = Field(default_factory=Memory)

    async def generate_code_solution(self, problem: str) -> Dict:
        """Generate a complete code solution following the 4-step process"""
        logger.info(f"🔧 Generating code solution for problem")
        
        # Create message for the code generation task
        message = Message(
            content=f"Generate a complete solution for this coding problem:\n\n{problem}",
            role="user"
        )
        
        # Add message to memory
        self.memory.add_message(message)
        
        # Generate response using system prompt and user message
        messages = [
            Message(role="system", content=self.system_prompt),
            message
        ]
        
        response_content = await self.llm.ask(
            messages=[msg.to_dict() for msg in messages] if hasattr(messages[0], 'to_dict') else messages,
            temperature=0.3
        )
        
        # Create response message
        response_message = Message(
            content=response_content,
            role="assistant"
        )
        
        # Add response to memory
        self.memory.add_message(response_message)
        
        # Parse the structured response
        result = {
            "problem": problem,
            "solution": response_content,
            "agent_state": AgentState.FINISHED.value
        }
        
        logger.info("✅ Code solution generated successfully")
        return result

    async def run(self, request: str, **kwargs) -> Dict:
        """Main entry point for generating code solutions"""
        try:
            result = await self.generate_code_solution(request)
            return result
        except Exception as e:
            logger.error(f"❌ Error in code data generation: {e}")
            import traceback
            traceback.print_exc()
            return {
                "error": str(e),
                "agent_state": AgentState.ERROR.value
            }