from evo_optimizer import EvoOptimizer
from FlowGen import FlowGen
from evo_optimizer import FlowGenome
from typing import Dict, Any, List
import json
from tools.base import Configuration, Server
import asyncio
from tools.unified_tool import UnifiedTool, ToolRegistry
from utils.llm_service import async_client
from agent.Agent_async import Actor
import os
import base64


# 读取gaia_level1_tasks.jsonl文件
with open('gaia_level1_tasks.jsonl', 'r', encoding='utf-8') as f:
    tasks = [json.loads(line) for line in f]


task = tasks[6]
print(task['Question'])


if task['file_name'] != "":
    print("需要进行文件分析: ", task['file_name'])
    task['file_path'] = os.path.join("C:\\Users\\87515\\Documents\\PyProject\\AutoAgentFlow\\Benchmark\\gaia\\test\\", task['file_name'])

tool_registry = ToolRegistry()

async def deepthink(question: str) -> str:
    """deepseekthink is a tool that is very good at reasoning.

    :param question: The question to answer
    :return: The answer to the question
    """
    client = await async_client()

    sys_prompt = f"""
    You are an AI assistant that is very good at reasoning.  
    Please answer the following questions as well as possible.
    Question: {question}
    """

    response = await client.chat.completions.create(
        model="gpt-4.1",
        messages=[{"role": "system", "content": sys_prompt}]
    )

    return response.choices[0].message.content


async def visual_analysis(question: str, file_path: str) -> str:
    """visual_analysis is a tool that is very good at analyzing images.

    :param question: The question to answer
    :param file_path: The path to the image file
    :return: The answer to the question
    """
    def encode_image(image_path: str) -> str:
        with open(image_path, "rb") as image_file:
            return base64.b64encode(image_file.read()).decode('utf-8')
    
    image = encode_image(file_path)

    client = await async_client()
    sys_prompt = f"""
    You are an AI assistant that is very good at analyzing images.
    Please answer the following questions based on the image.
    Question: {question}
    """

    response = await client.chat.completions.create(
        model="gpt-4o-2024-11-20",
        messages=[
        {
            "role": "user",
            "content": [
                {"type": "text", "text": sys_prompt},
                {
                    "type": "image_url",
                    "image_url": {
                        "url": f"data:image/png;base64,{image}"
                    }
                }
            ]
        }
    ],
    )

    return response.choices[0].message.content

async def main():
    # Register function-based tools
    # tool_registry.register_function(calculator)
    # tool_registry.register_function(text_analyzer)
    
    # Load and initialize MCP servers
    config = Configuration()
    server_config = config.load_config("tools/test_servers_config.json")

    servers = [
        Server(name, srv_config)
        for name, srv_config in server_config["mcpServers"].items()
    ]

    for server in servers:
        await server.initialize()

    # Register MCP server tools
    for server in servers:
        await tool_registry.register_server_tools(server)

    tool_registry.register_function(deepthink)
    tool_registry.register_function(visual_analysis)
    # Print all tool descriptions
    # tools_description = tool_registry.get_tool_descriptions()
    # print(tools_description)
    
    #await chat_with_tools(task['Question'], tool_registry.get_tool_descriptions(), tool_registry.get_all_tools())
    
    actor = Actor(tool_registry.get_all_tools())
    result = await actor.process(task)
    print(result)
    
    print(result['result'])

    for server in servers:
         await server.cleanup()


if __name__ == "__main__":
    asyncio.run(main())