|
@@ -0,0 +1,46 @@
|
|
|
+import logging
|
|
|
+
|
|
|
+from apps.rag.search.main import SearchResult
|
|
|
+from duckduckgo_search import DDGS
|
|
|
+from config import SRC_LOG_LEVELS
|
|
|
+
|
|
|
+log = logging.getLogger(__name__)
|
|
|
+log.setLevel(SRC_LOG_LEVELS["RAG"])
|
|
|
+
|
|
|
+
|
|
|
+def search_duckduckgo(query: str, count: int) -> list[SearchResult]:
|
|
|
+ """
|
|
|
+ Search using DuckDuckGo's Search API and return the results as a list of SearchResult objects.
|
|
|
+ Args:
|
|
|
+ query (str): The query to search for
|
|
|
+ count (int): The number of results to return
|
|
|
+
|
|
|
+ Returns:
|
|
|
+ List[SearchResult]: A list of search results
|
|
|
+ """
|
|
|
+ # Use the DDGS context manager to create a DDGS object
|
|
|
+ with DDGS() as ddgs:
|
|
|
+ # Use the ddgs.text() method to perform the search
|
|
|
+ ddgs_gen = ddgs.text(
|
|
|
+ query, safesearch="moderate", max_results=count, backend="api"
|
|
|
+ )
|
|
|
+ # Check if there are search results
|
|
|
+ if ddgs_gen:
|
|
|
+ # Convert the search results into a list
|
|
|
+ search_results = [r for r in ddgs_gen]
|
|
|
+
|
|
|
+ # Create an empty list to store the SearchResult objects
|
|
|
+ results = []
|
|
|
+ # Iterate over each search result
|
|
|
+ for result in search_results:
|
|
|
+ # Create a SearchResult object and append it to the results list
|
|
|
+ results.append(
|
|
|
+ SearchResult(
|
|
|
+ link=result["href"],
|
|
|
+ title=result.get("title"),
|
|
|
+ snippet=result.get("body"),
|
|
|
+ )
|
|
|
+ )
|
|
|
+ print(results)
|
|
|
+ # Return the list of search results
|
|
|
+ return results
|