2024-05-06 04:27:46 +00:00
|
|
|
import logging
|
2024-08-14 12:46:31 +00:00
|
|
|
from typing import Optional
|
2024-05-06 04:27:46 +00:00
|
|
|
|
2024-08-27 22:10:27 +00:00
|
|
|
import requests
|
2024-12-12 02:05:42 +00:00
|
|
|
from open_webui.retrieval.web.main import SearchResult, get_filtered_results
|
2024-09-04 14:54:48 +00:00
|
|
|
from open_webui.env import SRC_LOG_LEVELS
|
2024-05-06 04:27:46 +00:00
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
log.setLevel(SRC_LOG_LEVELS["RAG"])
|
|
|
|
|
|
|
|
|
|
|
|
def search_google_pse(
|
2024-06-17 21:32:23 +00:00
|
|
|
api_key: str,
|
|
|
|
search_engine_id: str,
|
|
|
|
query: str,
|
|
|
|
count: int,
|
2024-08-14 12:46:31 +00:00
|
|
|
filter_list: Optional[list[str]] = None,
|
2024-05-06 04:27:46 +00:00
|
|
|
) -> list[SearchResult]:
|
|
|
|
"""Search using Google's Programmable Search Engine API and return the results as a list of SearchResult objects.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
api_key (str): A Programmable Search Engine API key
|
|
|
|
search_engine_id (str): A Programmable Search Engine ID
|
|
|
|
query (str): The query to search for
|
|
|
|
"""
|
|
|
|
url = "https://www.googleapis.com/customsearch/v1"
|
|
|
|
|
|
|
|
headers = {"Content-Type": "application/json"}
|
|
|
|
params = {
|
|
|
|
"cx": search_engine_id,
|
|
|
|
"q": query,
|
|
|
|
"key": api_key,
|
2024-06-02 02:57:00 +00:00
|
|
|
"num": count,
|
2024-05-06 04:27:46 +00:00
|
|
|
}
|
|
|
|
|
2024-05-06 08:39:25 +00:00
|
|
|
response = requests.request("GET", url, headers=headers, params=params)
|
2024-05-06 04:27:46 +00:00
|
|
|
response.raise_for_status()
|
|
|
|
|
|
|
|
json_response = response.json()
|
|
|
|
results = json_response.get("items", [])
|
2024-06-17 07:35:27 +00:00
|
|
|
if filter_list:
|
|
|
|
results = get_filtered_results(results, filter_list)
|
2024-05-06 04:27:46 +00:00
|
|
|
return [
|
|
|
|
SearchResult(
|
2024-05-06 08:39:25 +00:00
|
|
|
link=result["link"],
|
|
|
|
title=result.get("title"),
|
|
|
|
snippet=result.get("snippet"),
|
2024-05-06 04:27:46 +00:00
|
|
|
)
|
2024-06-17 07:35:27 +00:00
|
|
|
for result in results
|
2024-05-06 04:27:46 +00:00
|
|
|
]
|