123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- 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.get(
- external_url,
- headers={
- "User-Agent": "Open WebUI (https://github.com/open-webui/open-webui) RAG Bot",
- "Authorization": f"Bearer {external_api_key}",
- },
- params={
- "query": query,
- "count": count,
- }
- )
- response.raise_for_status()
- results = response.json()
- if filter_list:
- results = get_filtered_results(results, filter_list)
- return [
- SearchResult(
- link=result.get("link"),
- title=result.get("title"),
- snippet=result.get("snippet"),
- )
- for result in results[:count]
- ]
- except Exception as e:
- log.error(f"Error in External search: {e}")
- return []
|