"""
Environment Interface

Defines a minimal interface for environment operations that GUI agents need.
This provides a clean abstraction layer between agents and environments.
"""

from abc import ABC, abstractmethod
from typing import Any, Dict, List, Optional


class EnvironmentInterface(ABC):
    """
    Abstract interface for environment operations.
    
    This interface defines the minimum set of methods that an environment
    must provide for GUI agents to interact with it.
    """
    
    @abstractmethod
    def get_current_observation(self) -> Dict[str, Any]:
        """
        Get the current observation from the environment.
        
        Returns:
            Dict containing:
                - screenshot: PIL Image or path
                - ui_elements: List of UI elements
                - ui_content: String representation of UI
                - Any other environment-specific data
        """
        pass
    
    @abstractmethod
    def execute_action(self, action: Any) -> Dict[str, Any]:
        """
        Execute an action in the environment.
        
        Args:
            action: Action to execute (format depends on environment)
            
        Returns:
            Dict containing:
                - success: Whether the action succeeded
                - feedback: Execution feedback message
                - new_observation: Observation after action
        """
        pass
    
    @abstractmethod
    def reset(self) -> None:
        """Reset the environment to initial state."""
        pass
    
    @abstractmethod
    def is_done(self) -> bool:
        """Check if the task is completed."""
        pass
    
    @property
    @abstractmethod
    def environment_type(self) -> str:
        """
        Return the environment type.
        
        Returns:
            str: One of 'android', 'web', 'desktop', etc.
        """
        pass

