from dataclasses import dataclass, field
from typing import Optional, Dict, Any

@dataclass
class AgentConfig:
    """
    Configuration container for instantiating LLM-based survey agents.

    Attributes:
        agent_type (str): The backend or provider of the agent.
            Examples: "openai", "claude", "custom".
        model_name (str): Name of the model to use.
            Examples: "gpt-4o", "gpt-3.5-turbo", "claude-3-sonnet".
        formality (str): Optional system prompt extension to specify tone,
            response formatting, or constraints. Default is an empty string.
        agent_kwargs (Dict[str, Any]): Additional keyword arguments passed
            to the agent constructor or API call (e.g., temperature, max_tokens).
    """
    agent_type: str                   # e.g., "openai", "claude", "custom"
    model_name: str                   # e.g., "gpt-4o", "claude-3-sonnet"
    formality: str = ""              # Extra prompt instruction
    agent_kwargs: Dict[str, Any] = field(default_factory=dict)  # Other params like temperature, max_tokens