"""
Base GUI Agent Interface

Defines the abstract interface that all GUI agents must implement.
This is environment-agnostic and can work with Android, Web, Desktop, etc.
"""

from abc import ABC, abstractmethod
from typing import Any

from autorpa.utils.models import ReActTraj

class BaseGUIAgent(ABC):
    """
    Abstract base class for GUI agents.
    
    Any agent (React*, DroidRun, Custom agents, etc.) must implement
    this interface to be compatible with the AutoRPA framework.
    
    Key Responsibilities:
    1. Explore a task and return a ReActTraj
    2. Convert agent-specific trajectory format to ReActTraj
    3. Declare supported environment type
    """
    
    @abstractmethod
    async def explore_task(
        self,
        task: Any,
        env_op: Any,
        max_steps: int = 20,
        **kwargs
    ) -> ReActTraj:
        """
        Explore a task and return a ReActTraj.
        
        This is the main method that performs task exploration using
        the agent's native exploration strategy (ReAct, planning, etc.).
        
        Args:
            task: Task object (can be AndroidWorld task, web task, etc.)
            env_interface: Environment operation interface
            max_steps: Maximum number of steps allowed
            **kwargs: Additional agent-specific parameters
            
        Returns:
            ReActTraj: ReAct trajectory
            
        Raises:
            Exception: If exploration fails
        """
        pass
    
        """
        Convert agent-specific trajectory format to ReActTraj.
        
        Each agent has its own trajectory format. This method normalizes
        it into the standard three-layer format.
        
        Args:
            agent_specific_traj: Agent's native trajectory data
            task_type: Task type/template name
            task_goal: Task goal/instruction
            **kwargs: Additional conversion parameters including success metrics:
                - env_success_score: Environment evaluation score
                - agent_done_bool: Whether agent completed the task
                - final_success_score: Final score (env_success_score if agent_done_bool else 0.0)
                - final_success_bool: Final success flag (final_success_score > 0.5 and agent_done_bool)
            
        Returns:
            ReActTraj: ReAct trajectory
        """
        pass
    
    @property
    @abstractmethod
    def environment_type(self) -> str:
        """
        Return the environment type this agent supports.
        
        Returns:
            str: One of 'android', 'web', 'desktop', 'hybrid'
        """
        pass
    
    @property
    @abstractmethod
    def agent_name(self) -> str:
        """
        Return the agent's name/identifier.
        
        Returns:
            str: Agent name (e.g., 'react_star', 'droidrun', 'custom_agent')
        """
        pass
    
    def reset(self) -> None:
        """
        Reset agent state (optional).
        
        Some agents may need to reset internal state between tasks.
        Default implementation does nothing.
        """
        pass
    
    def cleanup(self) -> None:
        """
        Cleanup resources (optional).
        
        Called when the agent is no longer needed.
        Default implementation does nothing.
        """
        pass
    
    def get_agent_info(self) -> dict:
        """
        Get agent information (optional).
        
        Returns:
            dict: Agent metadata (version, capabilities, etc.)
        """
        return {
            "agent_name": self.agent_name,
            "environment_type": self.environment_type,
            "version": "1.0",
        }

