import abc
from typing import Any, Dict, Optional
import logging


class BaseAgent(abc.ABC):
    """Abstract base class for all agents."""

    def __init__(self, llm_client: Any, name: str, logger: Optional[logging.Logger] = None):
        self.llm = llm_client
        self.name = name
        self._logger = logger or logging.getLogger(f"{__name__}.{name}")

    @abc.abstractmethod
    def run(self, inputs: Dict[str, Any]) -> Dict[str, Any]:
        """Execute the agent. Input and output are dicts for easy pipelining."""
        raise NotImplementedError

    def build_prompt(self, template: str, **kwargs: Any) -> str:
        self.logger.debug(f"Agent {self.name} building prompt with template length: {len(template)}")
        self.logger.debug(f"Agent {self.name} prompt kwargs: {list(kwargs.keys())}")
        return template.format(**kwargs)

    def llm_complete(self, prompt: str, **kwargs) -> str:
        """Call LLM and log the full prompt/response."""
        # Log the full prompt.
        self.logger.info("="*80)
        self.logger.info(f"[{self.name}] Full prompt:")
        self.logger.info("-"*80)
        self.logger.info(prompt)
        self.logger.info("="*80)
        
        # Call LLM.
        response = self.llm.complete(prompt, **kwargs)
        
        # Log the full response.
        self.logger.info("="*80)
        self.logger.info(f"[{self.name}] Full response:")
        self.logger.info("-"*80)
        self.logger.info(response)
        self.logger.info("="*80)
        
        return response

    @property
    def logger(self) -> logging.Logger:
        return self._logger
    
    @logger.setter
    def logger(self, new_logger: logging.Logger):
        """Set a new logger."""
        self._logger = new_logger 