"""
Orchestra Core - SubmitTool (提交工具)

用于 MainAgent 提交任务结果进行验证:
1. 触发环境的验证机制
2. 返回验证结果（成功/失败，奖励值）

设计要点:
- 只有 MainAgent 可以调用 submit
- SubAgent 只能通过 finish 报告进度
"""
from __future__ import annotations

from typing import Any, Dict

from orchestra_core.interfaces import BaseTool, Environment


class SubmitTool(BaseTool):
    """提交工具 - 提交任务结果进行验证"""
    
    def __init__(self, env: Environment):
        """
        初始化提交工具
        
        Args:
            env: 执行环境
        """
        self._env = env
    
    @property
    def name(self) -> str:
        return "submit"
    
    @property
    def description(self) -> str:
        return "Submit current solution for verification and get reward"
    
    @property
    def parameters(self) -> Dict[str, Any]:
        return {
            "type": "object",
            "properties": {
                "reason": {
                    "type": "string",
                    "description": "Reason for submission"
                },
            },
            "required": ["reason"]
        }
    
    async def __call__(self, reason: str = "") -> Dict[str, Any]:
        """
        执行提交
        
        Args:
            reason: 提交原因
        
        Returns:
            Dict: 验证结果
        """
        # 检查容器是否就绪
        if not hasattr(self._env, '_container_started') or not self._env._container_started:
            return {
                "success": False,
                "reward": 0.0,
                "done": True,
                "error": "No container running"
            }
        
        # 执行提交
        submit_action = {"action": "submit", "params": {}}
        obs, reward, done, info = await self._env.step(submit_action)
        
        return {
            "success": reward > 0,
            "reward": float(reward),
            "done": done,
            "observation": obs,
            "info": info,
        }


class CompleteTool(BaseTool):
    """完成工具 - 标记任务完成（用于问答类任务）"""
    
    def __init__(self):
        """初始化完成工具"""
        pass
    
    @property
    def name(self) -> str:
        return "complete"
    
    @property
    def description(self) -> str:
        return "Mark task as complete with final answer"
    
    @property
    def parameters(self) -> Dict[str, Any]:
        return {
            "type": "object",
            "properties": {
                "answer": {
                    "type": "string",
                    "description": "Final answer"
                },
            },
            "required": ["answer"]
        }
    
    async def __call__(self, answer: str = "") -> Dict[str, Any]:
        """
        标记完成
        
        Args:
            answer: 最终答案
        
        Returns:
            Dict: 完成结果
        """
        return {
            "success": True,
            "reward": 0.0,  # 实际奖励由外部验证
            "done": True,
            "answer": answer,
        }
