reranker.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. # coding=utf-8
  2. """
  3. @project: MaxKB
  4. @Author:虎
  5. @file: embedding.py
  6. @date:2024/7/12 15:10
  7. @desc:
  8. """
  9. from typing import Dict
  10. from django.utils.translation import gettext as _
  11. from common import forms
  12. from common.exception.app_exception import AppApiException
  13. from common.forms import BaseForm
  14. from models_provider.base_model_provider import BaseModelCredential, ValidCode
  15. from models_provider.impl.ollama_model_provider.model.reranker import OllamaReranker
  16. from langchain_core.documents import BaseDocumentCompressor, Document
  17. from django.utils.translation import gettext_lazy as _, gettext
  18. class OllamaReRankModelCredential(BaseForm, BaseModelCredential):
  19. def is_valid(self, model_type: str, model_name, model_credential: Dict[str, object], model_params, provider,
  20. raise_exception=False):
  21. if not model_type == 'RERANKER':
  22. raise AppApiException(ValidCode.valid_error.value,
  23. gettext('{model_type} Model type is not supported').format(model_type=model_type))
  24. model_type_list = provider.get_model_type_list()
  25. if not any(list(filter(lambda mt: mt.get('value') == model_type, model_type_list))):
  26. raise AppApiException(ValidCode.valid_error.value,
  27. _('{model_type} Model type is not supported').format(model_type=model_type))
  28. try:
  29. model_list = provider.get_base_model_list(model_credential.get('api_base'))
  30. except Exception as e:
  31. raise AppApiException(ValidCode.valid_error.value, _('API domain name is invalid'))
  32. exist = [model for model in (model_list.get('models') if model_list.get('models') is not None else []) if
  33. model.get('model') == model_name or model.get('model').replace(":latest", "") == model_name]
  34. if len(exist) == 0:
  35. raise AppApiException(ValidCode.model_not_fount,
  36. _('The model does not exist, please download the model first'))
  37. try:
  38. model: OllamaReranker = provider.get_model(model_type, model_name, model_credential)
  39. model.compress_documents([Document(page_content=gettext('Hello'))], gettext('Hello'))
  40. except Exception as e:
  41. if isinstance(e, AppApiException):
  42. raise e
  43. if raise_exception:
  44. raise AppApiException(ValidCode.valid_error.value,
  45. gettext(
  46. 'Verification failed, please check whether the parameters are correct: {error}').format(
  47. error=str(e)))
  48. else:
  49. return False
  50. return True
  51. def encryption_dict(self, model_info: Dict[str, object]):
  52. return model_info
  53. def build_model(self, model_info: Dict[str, object]):
  54. for key in ['model']:
  55. if key not in model_info:
  56. raise AppApiException(500, _('{key} is required').format(key=key))
  57. return self
  58. api_base = forms.TextInputField('API URL', required=True)