external.py 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. import logging
  2. import requests
  3. from typing import Optional, List, Tuple
  4. from open_webui.env import SRC_LOG_LEVELS
  5. from open_webui.retrieval.models.base_reranker import BaseReranker
  6. log = logging.getLogger(__name__)
  7. log.setLevel(SRC_LOG_LEVELS["RAG"])
  8. class ExternalReranker(BaseReranker):
  9. def __init__(
  10. self,
  11. api_key: str,
  12. url: str = "http://localhost:8080/v1/rerank",
  13. model: str = "reranker",
  14. ):
  15. self.api_key = api_key
  16. self.url = url
  17. self.model = model
  18. def predict(self, sentences: List[Tuple[str, str]]) -> Optional[List[float]]:
  19. query = sentences[0][0]
  20. docs = [i[1] for i in sentences]
  21. payload = {
  22. "model": self.model,
  23. "query": query,
  24. "documents": docs,
  25. "top_n": len(docs),
  26. }
  27. try:
  28. log.info(f"ExternalReranker:predict:model {self.model}")
  29. log.info(f"ExternalReranker:predict:query {query}")
  30. r = requests.post(
  31. f"{self.url}",
  32. headers={
  33. "Content-Type": "application/json",
  34. "Authorization": f"Bearer {self.api_key}",
  35. },
  36. json=payload,
  37. )
  38. r.raise_for_status()
  39. data = r.json()
  40. if "results" in data:
  41. sorted_results = sorted(data["results"], key=lambda x: x["index"])
  42. return [result["relevance_score"] for result in sorted_results]
  43. else:
  44. log.error("No results found in external reranking response")
  45. return None
  46. except Exception as e:
  47. log.exception(f"Error in external reranking: {e}")
  48. return None