import logging from typing import Optional, List import requests from open_webui.retrieval.web.main import SearchResult, get_filtered_results from open_webui.env import SRC_LOG_LEVELS log = logging.getLogger(__name__) log.setLevel(SRC_LOG_LEVELS["RAG"]) def search_external( external_url: str, external_api_key: str, query: str, count: int, filter_list: Optional[List[str]] = None, ) -> List[SearchResult]: try: response = requests.post( external_url, headers={ "User-Agent": "Open WebUI (https://github.com/open-webui/open-webui) RAG Bot", "Authorization": f"Bearer {external_api_key}", }, json={ "query": query, "count": count, }, ) response.raise_for_status() results = response.json() if filter_list: results = get_filtered_results(results, filter_list) results = [ SearchResult( link=result.get("link"), title=result.get("title"), snippet=result.get("snippet"), ) for result in results[:count] ] log.info(f"External search results: {results}") return results except Exception as e: log.error(f"Error in External search: {e}") return []