"""
Orchestra Core - 核心接口定义

定义框架的核心抽象接口，具体实现由使用方提供。
"""
from __future__ import annotations

from abc import ABC, abstractmethod
from dataclasses import dataclass, field
from typing import Any, Dict, List, Optional, Protocol, Tuple, TypeVar


# ============== 基础数据类型 ==============

Action = Dict[str, Any]
Observation = Dict[str, Any]


@dataclass
class BasicInfo:
    """环境基本信息"""
    env_id: str
    instruction: str
    action_space: str
    max_steps: int
    meta_data: Dict[str, Any] = field(default_factory=dict)


@dataclass
class StepRecord:
    """单步执行记录"""
    observation: Any
    action: Action
    reward: float
    raw_response: str
    done: bool
    info: Dict[str, Any] = field(default_factory=dict)
    raw_input: Optional[str] = None


@dataclass
class LevelResult:
    """任务执行结果"""
    model: str
    total_reward: float
    steps: int
    done: bool
    trace: List[StepRecord]
    cost: float
    input_tokens: int = 0
    output_tokens: int = 0
    timestamp: str = ""


# ============== LLM 接口 ==============

class LLMInterface(Protocol):
    """LLM 调用接口协议"""
    
    async def __call__(self, prompt: str) -> str:
        """调用 LLM 生成响应"""
        ...
    
    def get_usage_summary(self) -> Dict[str, Any]:
        """获取使用统计"""
        ...


# ============== 环境接口 ==============

class Environment(ABC):
    """执行环境抽象基类"""
    
    @abstractmethod
    def get_basic_info(self) -> BasicInfo:
        """获取环境基本信息"""
        ...
    
    @abstractmethod
    async def reset(self, seed: Optional[int] = None) -> Observation:
        """重置环境"""
        ...
    
    @abstractmethod
    async def step(self, action: Action) -> Tuple[Observation, float, bool, Dict[str, Any]]:
        """执行动作"""
        ...
    
    async def close(self):
        """关闭环境，清理资源"""
        pass
    
    async def cleanup_container_if_exists(self):
        """清理已存在的容器（如有）"""
        pass


# ============== Prompt 构建器接口 ==============

class PromptBuilder(Protocol):
    """Prompt 构建器协议"""
    
    @staticmethod
    def build_prompt(
        instruction: str,
        meta: Dict[str, Any],
        tools_description: str,
        prior_context: str,
        attempt_index: int,
        max_attempts: int,
        sub_models: List[str],
        subtask_history: str = "",
        model_to_alias: Optional[Dict[str, str]] = None,
    ) -> str:
        """构建 MainAgent 的决策 prompt"""
        ...


# ============== 工具接口 ==============

class BaseTool(ABC):
    """工具基类"""
    
    @property
    @abstractmethod
    def name(self) -> str:
        """工具名称"""
        ...
    
    @property
    @abstractmethod
    def description(self) -> str:
        """工具描述"""
        ...
    
    @property
    @abstractmethod
    def parameters(self) -> Dict[str, Any]:
        """工具参数 schema"""
        ...
    
    @abstractmethod
    async def __call__(self, **kwargs) -> Dict[str, Any]:
        """执行工具"""
        ...


# ============== 智能体接口 ==============

class BaseAgent(ABC):
    """智能体基类"""
    
    llm: LLMInterface
    
    @abstractmethod
    def reset(self, env_info: BasicInfo) -> None:
        """重置智能体状态"""
        ...
    
    @abstractmethod
    async def step(self, observation: Any, history: List, **kwargs) -> Tuple[Action, str]:
        """执行一步决策"""
        ...
