reranker.py 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. import traceback
  2. from typing import Dict
  3. from django.utils.translation import gettext_lazy as _, gettext
  4. from langchain_core.documents import Document
  5. from common import forms
  6. from common.exception.app_exception import AppApiException
  7. from common.forms import BaseForm, TooltipLabel
  8. from models_provider.base_model_provider import ValidCode, BaseModelCredential
  9. class BedrockRerankerModelParams(BaseForm):
  10. top_n = forms.SliderField(TooltipLabel(_('Top N'),
  11. _('Number of top documents to return after reranking')),
  12. required=True, default_value=3,
  13. _min=1,
  14. _max=20,
  15. _step=1,
  16. precision=0)
  17. class BedrockRerankerCredential(BaseForm, BaseModelCredential):
  18. access_key_id = forms.PasswordInputField(_('Access Key ID'), required=True)
  19. secret_access_key = forms.PasswordInputField(_('Secret Access Key'), required=True)
  20. region_name = forms.TextInputField(_('Region Name'), required=True, default_value='us-east-1')
  21. base_url = forms.TextInputField(_('Base URL'), required=False)
  22. def is_valid(self, model_type: str, model_name: str, model_credential: Dict[str, object], model_params,
  23. provider,
  24. raise_exception: bool = False):
  25. model_type_list = provider.get_model_type_list()
  26. if not any(list(filter(lambda mt: mt.get('value') == model_type, model_type_list))):
  27. raise AppApiException(ValidCode.valid_error.value, _('Model type is not supported'))
  28. for key in ['access_key_id', 'secret_access_key', 'region_name']:
  29. if key not in model_credential:
  30. if raise_exception:
  31. raise AppApiException(ValidCode.valid_error.value, _('%(key)s is required') % {'key': key})
  32. else:
  33. return False
  34. try:
  35. model = provider.get_model(model_type, model_name, model_credential, **model_params)
  36. # Use top_n=1 for validation since we only have 1 test document
  37. test_docs = [
  38. Document(page_content=str(_('Hello'))),
  39. Document(page_content=str(_('World'))),
  40. Document(page_content=str(_('Test')))
  41. ]
  42. model.compress_documents(test_docs, str(_('Hello')))
  43. except Exception as e:
  44. traceback.print_exc()
  45. if isinstance(e, AppApiException):
  46. raise e
  47. if raise_exception:
  48. raise AppApiException(ValidCode.valid_error.value,
  49. _('Verification failed, please check whether the parameters are correct: %(error)s') % {'error': str(e)})
  50. else:
  51. return False
  52. return True
  53. def encryption_dict(self, model: Dict[str, object]):
  54. return {**model, 'access_key_id': super().encryption(model.get('access_key_id', '')),
  55. 'secret_access_key': super().encryption(model.get('secret_access_key', ''))}
  56. def get_model_params_setting_form(self, model_name):
  57. return BedrockRerankerModelParams()