mirror of
https://gitee.com/wanwujie/deer-flow
synced 2026-04-05 07:02:13 +08:00
* feat: implement UI * feat: config max_search_results for search engine via api --------- Co-authored-by: Henry Li <henry1943@163.com>
66 lines
2.3 KiB
Python
66 lines
2.3 KiB
Python
# Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
|
|
# SPDX-License-Identifier: MIT
|
|
|
|
import json
|
|
import logging
|
|
import os
|
|
|
|
from langchain_community.tools import BraveSearch, DuckDuckGoSearchResults
|
|
from langchain_community.tools.arxiv import ArxivQueryRun
|
|
from langchain_community.utilities import ArxivAPIWrapper, BraveSearchWrapper
|
|
|
|
from src.config import SearchEngine, SELECTED_SEARCH_ENGINE
|
|
from src.tools.tavily_search.tavily_search_results_with_images import (
|
|
TavilySearchResultsWithImages,
|
|
)
|
|
|
|
from src.tools.decorators import create_logged_tool
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
# Create logged versions of the search tools
|
|
LoggedTavilySearch = create_logged_tool(TavilySearchResultsWithImages)
|
|
LoggedDuckDuckGoSearch = create_logged_tool(DuckDuckGoSearchResults)
|
|
LoggedBraveSearch = create_logged_tool(BraveSearch)
|
|
LoggedArxivSearch = create_logged_tool(ArxivQueryRun)
|
|
|
|
|
|
# Get the selected search tool
|
|
def get_web_search_tool(max_search_results: int):
|
|
if SELECTED_SEARCH_ENGINE == SearchEngine.TAVILY.value:
|
|
return LoggedTavilySearch(
|
|
name="web_search",
|
|
max_results=max_search_results,
|
|
include_raw_content=True,
|
|
include_images=True,
|
|
include_image_descriptions=True,
|
|
)
|
|
elif SELECTED_SEARCH_ENGINE == SearchEngine.DUCKDUCKGO.value:
|
|
return LoggedDuckDuckGoSearch(name="web_search", max_results=max_search_results)
|
|
elif SELECTED_SEARCH_ENGINE == SearchEngine.BRAVE_SEARCH.value:
|
|
return LoggedBraveSearch(
|
|
name="web_search",
|
|
search_wrapper=BraveSearchWrapper(
|
|
api_key=os.getenv("BRAVE_SEARCH_API_KEY", ""),
|
|
search_kwargs={"count": max_search_results},
|
|
),
|
|
)
|
|
elif SELECTED_SEARCH_ENGINE == SearchEngine.ARXIV.value:
|
|
return LoggedArxivSearch(
|
|
name="web_search",
|
|
api_wrapper=ArxivAPIWrapper(
|
|
top_k_results=max_search_results,
|
|
load_max_docs=max_search_results,
|
|
load_all_available_meta=True,
|
|
),
|
|
)
|
|
else:
|
|
raise ValueError(f"Unsupported search engine: {SELECTED_SEARCH_ENGINE}")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
results = LoggedDuckDuckGoSearch(
|
|
name="web_search", max_results=3, output_format="list"
|
|
).invoke("cute panda")
|
|
print(json.dumps(results, indent=2, ensure_ascii=False))
|