|
@@ -59,7 +59,7 @@ from open_webui.retrieval.web.serpstack import search_serpstack
|
|
|
from open_webui.retrieval.web.tavily import search_tavily
|
|
|
from open_webui.retrieval.web.bing import search_bing
|
|
|
from open_webui.retrieval.web.exa import search_exa
|
|
|
-
|
|
|
+from open_webui.retrieval.web.perplexity import search_perplexity
|
|
|
|
|
|
from open_webui.retrieval.utils import (
|
|
|
get_embedding_function,
|
|
@@ -405,6 +405,7 @@ async def get_rag_config(request: Request, user=Depends(get_admin_user)):
|
|
|
"bing_search_v7_endpoint": request.app.state.config.BING_SEARCH_V7_ENDPOINT,
|
|
|
"bing_search_v7_subscription_key": request.app.state.config.BING_SEARCH_V7_SUBSCRIPTION_KEY,
|
|
|
"exa_api_key": request.app.state.config.EXA_API_KEY,
|
|
|
+ "perplexity_api_key": request.app.state.config.PERPLEXITY_API_KEY,
|
|
|
"result_count": request.app.state.config.RAG_WEB_SEARCH_RESULT_COUNT,
|
|
|
"trust_env": request.app.state.config.RAG_WEB_SEARCH_TRUST_ENV,
|
|
|
"concurrent_requests": request.app.state.config.RAG_WEB_SEARCH_CONCURRENT_REQUESTS,
|
|
@@ -465,6 +466,7 @@ class WebSearchConfig(BaseModel):
|
|
|
bing_search_v7_endpoint: Optional[str] = None
|
|
|
bing_search_v7_subscription_key: Optional[str] = None
|
|
|
exa_api_key: Optional[str] = None
|
|
|
+ perplexity_api_key: Optional[str] = None
|
|
|
result_count: Optional[int] = None
|
|
|
concurrent_requests: Optional[int] = None
|
|
|
trust_env: Optional[bool] = None
|
|
@@ -617,6 +619,8 @@ async def update_rag_config(
|
|
|
|
|
|
request.app.state.config.EXA_API_KEY = form_data.web.search.exa_api_key
|
|
|
|
|
|
+ request.app.state.config.PERPLEXITY_API_KEY = form_data.web.search.perplexity_api_key
|
|
|
+
|
|
|
request.app.state.config.RAG_WEB_SEARCH_RESULT_COUNT = (
|
|
|
form_data.web.search.result_count
|
|
|
)
|
|
@@ -683,6 +687,7 @@ async def update_rag_config(
|
|
|
"bing_search_v7_endpoint": request.app.state.config.BING_SEARCH_V7_ENDPOINT,
|
|
|
"bing_search_v7_subscription_key": request.app.state.config.BING_SEARCH_V7_SUBSCRIPTION_KEY,
|
|
|
"exa_api_key": request.app.state.config.EXA_API_KEY,
|
|
|
+ "perplexity_api_key": request.app.state.config.PERPLEXITY_API_KEY,
|
|
|
"result_count": request.app.state.config.RAG_WEB_SEARCH_RESULT_COUNT,
|
|
|
"concurrent_requests": request.app.state.config.RAG_WEB_SEARCH_CONCURRENT_REQUESTS,
|
|
|
"trust_env": request.app.state.config.RAG_WEB_SEARCH_TRUST_ENV,
|
|
@@ -1221,6 +1226,7 @@ def search_web(request: Request, engine: str, query: str) -> list[SearchResult]:
|
|
|
- SERPLY_API_KEY
|
|
|
- TAVILY_API_KEY
|
|
|
- EXA_API_KEY
|
|
|
+ - PERPLEXITY_API_KEY
|
|
|
- SEARCHAPI_API_KEY + SEARCHAPI_ENGINE (by default `google`)
|
|
|
- SERPAPI_API_KEY + SERPAPI_ENGINE (by default `google`)
|
|
|
Args:
|
|
@@ -1385,6 +1391,13 @@ def search_web(request: Request, engine: str, query: str) -> list[SearchResult]:
|
|
|
request.app.state.config.RAG_WEB_SEARCH_RESULT_COUNT,
|
|
|
request.app.state.config.RAG_WEB_SEARCH_DOMAIN_FILTER_LIST,
|
|
|
)
|
|
|
+ elif engine == "perplexity":
|
|
|
+ return search_perplexity(
|
|
|
+ request.app.state.config.PERPLEXITY_API_KEY,
|
|
|
+ query,
|
|
|
+ request.app.state.config.RAG_WEB_SEARCH_RESULT_COUNT,
|
|
|
+ request.app.state.config.RAG_WEB_SEARCH_DOMAIN_FILTER_LIST,
|
|
|
+ )
|
|
|
else:
|
|
|
raise Exception("No search engine API key found in environment variables")
|
|
|
|