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


class BaseGuardrailModel(ABC):
    """
    Abstract base class for Guardrail models
    Ensures any model (GPT-4, Claude, Llama, etc.) works with the same interface
    """
    
    @abstractmethod
    def is_risky(
        self, 
        action_nl: str, 
        image_file: Optional[str] = None,
        caution: Optional[str] = None
    ) -> Dict[str, str]:
        """
        Judge risky status from action converted to NL and image
        
        Args:
            action_nl: Action description converted to natural language
            image_file: Captured image file path (optional)
            caution: Safety warning (optional)
            
        Returns:
            Dict[str, str]: {
                'potential_risk': 'risky' or 'benign',
                'risk_type': risk type or 'none',
                'hazard': hazard description or 'none'
            }
        """
        pass
    
    def __call__(
        self, 
        action_nl: str, 
        image_file: Optional[str] = None,
        caution: Optional[str] = None
    ) -> Dict[str, str]:
        """
        Provide callable interface
        """
        return self.is_risky(action_nl, image_file, caution)

