"""
WebSearch tool for Qwen Code Python implementation.
"""
import os
import requests
from typing import Dict, Any, List
from .base_tool import BaseTool
from .tool_types import ToolKind


class WebSearchTool(BaseTool):
    """Tool for performing web searches using a search API."""
    Name = "web_search"
    
    def __init__(self, working_dir: str):
        super().__init__(
            self.Name,
            """Performs web searches to find relevant information. This tool helps gather up-to-date information from the internet to answer questions or provide context.""",
            {
                "type": "object",
                "properties": {
                    "query": {
                        "type": "string",
                        "description": "The search query.",
                        "minLength": 1
                    }
                },
                "required": ["query"],
            },
            ToolKind.FETCH
        )
        self.working_dir = working_dir
        
    def validate_params(self, params: Dict[str, Any]) -> str:
        error = super().validate_params(params)
        if error:
            return error
            
        query = params.get("query", "")
        if not query or not query.strip():
            return "Parameter 'query' must be a non-empty string."
            
        return None
        
    def get_description(self, params: Dict[str, Any]) -> str:
        """Get a description of the web search operation."""
        query = params.get("query", "")
        return f"Searching the web for: \"{query}\""
        
    def execute(self, params: Dict[str, Any]) -> Dict[str, Any]:
        error = self.validate_params(params)
        if error:
            return {
                "llmContent": f"Error: Invalid parameters provided. Reason: {error}",
                "returnDisplay": f"Error: {error}"
            }
            
        query = params["query"]
        
        try:
            # For this implementation, we'll use a simple DuckDuckGo search as an example
            # In a production implementation, you would use a proper search API like Tavily
            
            # Simple DuckDuckGo API search (instant answer)
            search_url = f"https://api.duckduckgo.com/?q={query}&format=json&no_html=1&skip_disambig=1"
            
            response = requests.get(search_url, timeout=10)
            response.raise_for_status()
            
            data = response.json()
            
            # Extract relevant information
            abstract = data.get("Abstract", "")
            abstract_text = data.get("AbstractText", "")
            answer = data.get("Answer", "")
            
            # Get related topics/links
            results = []
            related_topics = data.get("RelatedTopics", [])
            for topic in related_topics[:5]:  # Limit to first 5 results
                if "FirstURL" in topic and "Text" in topic:
                    results.append({
                        "title": topic["Text"][:100],  # Limit title length
                        "url": topic["FirstURL"],
                        "content": ""  # DuckDuckGo API doesn't provide full content
                    })
            
            # Prepare response content
            if abstract or abstract_text or answer:
                content_parts = []
                if abstract:
                    content_parts.append(f"Abstract: {abstract}")
                if abstract_text:
                    content_parts.append(f"Details: {abstract_text}")
                if answer:
                    content_parts.append(f"Answer: {answer}")
                
                main_content = "\n\n".join(content_parts)
            else:
                main_content = "No direct answer found. Here are related topics:"
                for result in results:
                    main_content += f"\n- {result['title']}: {result['url']}"
            
            # Add source information
            sources = [{"title": r["title"], "url": r["url"]} for r in results]
            
            return {
                "llmContent": main_content,
                "returnDisplay": f"Found information for query: \"{query}\"",
                "sources": sources
            }
            
        except requests.exceptions.RequestException as e:
            return {
                "llmContent": f"Error performing web search: Network error - {str(e)}",
                "returnDisplay": f"Error: Network error - {str(e)}"
            }
        except Exception as e:
            return {
                "llmContent": f"Error performing web search: {str(e)}",
                "returnDisplay": f"Error: {str(e)}"
            }