external.py 1.6 KB

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