Spaces:
Running
Running
import logging | |
from typing import Optional | |
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_kagi( | |
api_key: str, query: str, count: int, filter_list: Optional[list[str]] = None | |
) -> list[SearchResult]: | |
"""Search using Kagi's Search API and return the results as a list of SearchResult objects. | |
The Search API will inherit the settings in your account, including results personalization and snippet length. | |
Args: | |
api_key (str): A Kagi Search API key | |
query (str): The query to search for | |
count (int): The number of results to return | |
""" | |
url = "https://kagi.com/api/v0/search" | |
headers = { | |
"Authorization": f"Bot {api_key}", | |
} | |
params = {"q": query, "limit": count} | |
response = requests.get(url, headers=headers, params=params) | |
response.raise_for_status() | |
json_response = response.json() | |
search_results = json_response.get("data", []) | |
results = [ | |
SearchResult( | |
link=result["url"], title=result["title"], snippet=result.get("snippet") | |
) | |
for result in search_results | |
if result["t"] == 0 | |
] | |
print(results) | |
if filter_list: | |
results = get_filtered_results(results, filter_list) | |
return results | |