1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- 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 []
|