Report provider-specific search API keys correctly (#1202)

* fix(search): report provider-specific API keys

* fix(search): include provider env keys in status
This commit is contained in:
red person
2026-06-02 17:37:15 +03:00
committed by GitHub
parent f2f437f4a8
commit cc6e43da44
3 changed files with 68 additions and 2 deletions

View File

@@ -30,6 +30,7 @@ from .providers import (
tavily_search,
serper_search,
_get_search_settings,
_get_provider_key,
_get_result_count,
)
from .content import (
@@ -54,7 +55,7 @@ def get_search_config() -> Dict[str, Any]:
settings = _get_search_settings()
provider = settings.get("search_provider", "searxng")
config["active_provider"] = provider
config["has_api_key"] = bool((settings.get("search_api_key") or "").strip())
config["has_api_key"] = bool(_get_provider_key(provider))
config["result_count"] = _get_result_count()
if provider == "searxng":
from .providers import _get_search_instance

View File

@@ -64,7 +64,17 @@ def _get_provider_key(provider: str) -> str:
if val:
return val
# Legacy fallback: old shared search_api_key field
return (settings.get("search_api_key") or "").strip()
legacy = (settings.get("search_api_key") or "").strip()
if legacy:
return legacy
env_map = {
"brave": "DATA_BRAVE_API_KEY",
"google_pse": "GOOGLE_API_KEY",
"tavily": "TAVILY_API_KEY",
"serper": "SERPER_API_KEY",
}
env_name = env_map.get(provider, "")
return (os.environ.get(env_name) or "").strip() if env_name else ""
def _get_result_count() -> int:

View File

@@ -0,0 +1,55 @@
from services.search import core, providers
PROVIDER_ENV_KEYS = (
"DATA_BRAVE_API_KEY",
"GOOGLE_API_KEY",
"TAVILY_API_KEY",
"SERPER_API_KEY",
)
def _config(monkeypatch, settings):
for env_name in PROVIDER_ENV_KEYS:
monkeypatch.delenv(env_name, raising=False)
monkeypatch.setattr(core, "_get_search_settings", lambda: settings)
monkeypatch.setattr(providers, "_get_search_settings", lambda: settings)
return core.get_search_config()
def test_search_config_detects_active_provider_specific_key(monkeypatch):
config = _config(monkeypatch, {
"search_provider": "tavily",
"tavily_api_key": "tavily-key",
})
assert config["has_api_key"] is True
def test_search_config_ignores_key_for_different_provider(monkeypatch):
config = _config(monkeypatch, {
"search_provider": "brave",
"tavily_api_key": "tavily-key",
})
assert config["has_api_key"] is False
def test_search_config_keeps_legacy_shared_key_fallback(monkeypatch):
config = _config(monkeypatch, {
"search_provider": "serper",
"search_api_key": "legacy-key",
})
assert config["has_api_key"] is True
def test_search_config_detects_provider_env_key(monkeypatch):
settings = {"search_provider": "tavily"}
for env_name in PROVIDER_ENV_KEYS:
monkeypatch.delenv(env_name, raising=False)
monkeypatch.setenv("TAVILY_API_KEY", "env-key")
monkeypatch.setattr(core, "_get_search_settings", lambda: settings)
monkeypatch.setattr(providers, "_get_search_settings", lambda: settings)
assert core.get_search_config()["has_api_key"] is True
assert providers._get_provider_key("tavily") == "env-key"