from typing import Optional
from .base import BaseTool, ToolResult


class GetWeather(BaseTool):
    """示例：查询天气（演示工具调用与参数解析）。

    注意：该工具返回模拟数据，仅用于验证函数调用链路。
    """

    name: str = "get_weather"
    description: str = (
        "根据地名返回当天的模拟天气。用于演示函数调用流程；不要用于生产环境。"
    )
    input: str = "location: 城市或地点名称; unit: 可选温度单位 'c' 或 'f'"
    output: str = "包含温度、天气状况等的 JSON 对象"
    parameters: dict = {
        "type": "object",
        "properties": {
            "location": {
                "type": "string",
                "description": "城市或地点名称，例如 '北京'、'Shanghai'",
            },
            "unit": {
                "type": "string",
                "enum": ["c", "f"],
                "description": "温度单位，'c'摄氏度 或 'f'华氏度，默认 'c'",
            },
        },
        "required": ["location"],
    }

    def execute(self, location: str, unit: Optional[str] = "c") -> ToolResult:
        unit = (unit or "c").lower()
        mock_db = {
            "北京": {"cond": "晴", "temp_c": 18},
            "上海": {"cond": "多云", "temp_c": 20},
            "深圳": {"cond": "阵雨", "temp_c": 24},
            "hangzhou": {"cond": "阴", "temp_c": 19},
            "shanghai": {"cond": "多云", "temp_c": 20},
            "beijing": {"cond": "晴", "temp_c": 18},
        }

        rec = mock_db.get(location) or mock_db.get(location.lower())
        if not rec:
            # 未知地点也返回一个温和的默认值
            rec = {"cond": "晴", "temp_c": 21}

        temp_c = rec["temp_c"]
        if unit == "f":
            temp = round(temp_c * 9 / 5 + 32, 1)
            temp_key = "temp_f"
        else:
            temp = temp_c
            temp_key = "temp_c"

        return ToolResult(
            output={
                "location": location,
                "condition": rec["cond"],
                temp_key: temp,
                "unit": unit,
            }
        )
