Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

hit_testing_base.py 3.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. import logging
  2. from flask_login import current_user
  3. from flask_restx import marshal, reqparse
  4. from werkzeug.exceptions import Forbidden, InternalServerError, NotFound
  5. import services.dataset_service
  6. from controllers.console.app.error import (
  7. CompletionRequestError,
  8. ProviderModelCurrentlyNotSupportError,
  9. ProviderNotInitializeError,
  10. ProviderQuotaExceededError,
  11. )
  12. from controllers.console.datasets.error import DatasetNotInitializedError
  13. from core.errors.error import (
  14. LLMBadRequestError,
  15. ModelCurrentlyNotSupportError,
  16. ProviderTokenNotInitError,
  17. QuotaExceededError,
  18. )
  19. from core.model_runtime.errors.invoke import InvokeError
  20. from fields.hit_testing_fields import hit_testing_record_fields
  21. from services.dataset_service import DatasetService
  22. from services.hit_testing_service import HitTestingService
  23. logger = logging.getLogger(__name__)
  24. class DatasetsHitTestingBase:
  25. @staticmethod
  26. def get_and_validate_dataset(dataset_id: str):
  27. dataset = DatasetService.get_dataset(dataset_id)
  28. if dataset is None:
  29. raise NotFound("Dataset not found.")
  30. try:
  31. DatasetService.check_dataset_permission(dataset, current_user)
  32. except services.errors.account.NoPermissionError as e:
  33. raise Forbidden(str(e))
  34. return dataset
  35. @staticmethod
  36. def hit_testing_args_check(args):
  37. HitTestingService.hit_testing_args_check(args)
  38. @staticmethod
  39. def parse_args():
  40. parser = reqparse.RequestParser()
  41. parser.add_argument("query", type=str, location="json")
  42. parser.add_argument("retrieval_model", type=dict, required=False, location="json")
  43. parser.add_argument("external_retrieval_model", type=dict, required=False, location="json")
  44. return parser.parse_args()
  45. @staticmethod
  46. def perform_hit_testing(dataset, args):
  47. try:
  48. response = HitTestingService.retrieve(
  49. dataset=dataset,
  50. query=args["query"],
  51. account=current_user,
  52. retrieval_model=args["retrieval_model"],
  53. external_retrieval_model=args["external_retrieval_model"],
  54. limit=10,
  55. )
  56. return {"query": response["query"], "records": marshal(response["records"], hit_testing_record_fields)}
  57. except services.errors.index.IndexNotInitializedError:
  58. raise DatasetNotInitializedError()
  59. except ProviderTokenNotInitError as ex:
  60. raise ProviderNotInitializeError(ex.description)
  61. except QuotaExceededError:
  62. raise ProviderQuotaExceededError()
  63. except ModelCurrentlyNotSupportError:
  64. raise ProviderModelCurrentlyNotSupportError()
  65. except LLMBadRequestError:
  66. raise ProviderNotInitializeError(
  67. "No Embedding Model or Reranking Model available. Please configure a valid provider "
  68. "in the Settings -> Model Provider."
  69. )
  70. except InvokeError as e:
  71. raise CompletionRequestError(e.description)
  72. except ValueError as e:
  73. raise ValueError(str(e))
  74. except Exception as e:
  75. logger.exception("Hit testing failed.")
  76. raise InternalServerError(str(e))