Some checks failed
Create and publish Docker images with specific build args / build-main-image (linux/amd64, ubuntu-latest) (push) Has been cancelled
Create and publish Docker images with specific build args / build-main-image (linux/arm64, ubuntu-24.04-arm) (push) Has been cancelled
Create and publish Docker images with specific build args / build-cuda-image (linux/amd64, ubuntu-latest) (push) Has been cancelled
Create and publish Docker images with specific build args / build-cuda-image (linux/arm64, ubuntu-24.04-arm) (push) Has been cancelled
Create and publish Docker images with specific build args / build-cuda126-image (linux/amd64, ubuntu-latest) (push) Has been cancelled
Create and publish Docker images with specific build args / build-cuda126-image (linux/arm64, ubuntu-24.04-arm) (push) Has been cancelled
Create and publish Docker images with specific build args / build-ollama-image (linux/amd64, ubuntu-latest) (push) Has been cancelled
Create and publish Docker images with specific build args / build-ollama-image (linux/arm64, ubuntu-24.04-arm) (push) Has been cancelled
Create and publish Docker images with specific build args / build-slim-image (linux/amd64, ubuntu-latest) (push) Has been cancelled
Create and publish Docker images with specific build args / build-slim-image (linux/arm64, ubuntu-24.04-arm) (push) Has been cancelled
Create and publish Docker images with specific build args / merge-main-images (push) Has been cancelled
Create and publish Docker images with specific build args / merge-cuda-images (push) Has been cancelled
Create and publish Docker images with specific build args / merge-cuda126-images (push) Has been cancelled
Create and publish Docker images with specific build args / merge-ollama-images (push) Has been cancelled
Create and publish Docker images with specific build args / merge-slim-images (push) Has been cancelled
Python CI / Format Backend (3.11.x) (push) Has been cancelled
Python CI / Format Backend (3.12.x) (push) Has been cancelled
Frontend Build / Format & Build Frontend (push) Has been cancelled
Frontend Build / Frontend Unit Tests (push) Has been cancelled
Close inactive issues / close-issues (push) Has been cancelled
73 lines
2.4 KiB
Python
73 lines
2.4 KiB
Python
import logging
|
|
from typing import Optional
|
|
|
|
import requests
|
|
from open_webui.retrieval.web.main import SearchResult, get_filtered_results
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
def search_google_pse(
|
|
api_key: str,
|
|
search_engine_id: str,
|
|
query: str,
|
|
count: int,
|
|
filter_list: Optional[list[str]] = None,
|
|
referer: Optional[str] = None,
|
|
) -> list[SearchResult]:
|
|
"""Search using Google's Programmable Search Engine API and return the results as a list of SearchResult objects.
|
|
Handles pagination for counts greater than 10.
|
|
|
|
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
|
|
count (int): The number of results to return (max 100, as PSE max results per query is 10 and max page is 10)
|
|
filter_list (Optional[list[str]], optional): A list of keywords to filter out from results. Defaults to None.
|
|
|
|
Returns:
|
|
list[SearchResult]: A list of SearchResult objects.
|
|
"""
|
|
url = "https://www.googleapis.com/customsearch/v1"
|
|
|
|
headers = {"Content-Type": "application/json"}
|
|
if referer:
|
|
headers["Referer"] = referer
|
|
|
|
all_results = []
|
|
start_index = 1 # Google PSE start parameter is 1-based
|
|
|
|
while count > 0:
|
|
num_results_this_page = min(count, 10) # Google PSE max results per page is 10
|
|
params = {
|
|
"cx": search_engine_id,
|
|
"q": query,
|
|
"key": api_key,
|
|
"num": num_results_this_page,
|
|
"start": start_index,
|
|
}
|
|
response = requests.request("GET", url, headers=headers, params=params)
|
|
response.raise_for_status()
|
|
json_response = response.json()
|
|
results = json_response.get("items", [])
|
|
if results: # check if results are returned. If not, no more pages to fetch.
|
|
all_results.extend(results)
|
|
count -= len(
|
|
results
|
|
) # Decrement count by the number of results fetched in this page.
|
|
start_index += 10 # Increment start index for the next page
|
|
else:
|
|
break # No more results from Google PSE, break the loop
|
|
|
|
if filter_list:
|
|
all_results = get_filtered_results(all_results, filter_list)
|
|
|
|
return [
|
|
SearchResult(
|
|
link=result["link"],
|
|
title=result.get("title"),
|
|
snippet=result.get("snippet"),
|
|
)
|
|
for result in all_results
|
|
]
|