12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- import logging
- from flask_login import current_user
- from flask_restful import marshal, reqparse
- from werkzeug.exceptions import Forbidden, InternalServerError, NotFound
- import services.dataset_service
- from controllers.console.app.error import (
- CompletionRequestError,
- ProviderModelCurrentlyNotSupportError,
- ProviderNotInitializeError,
- ProviderQuotaExceededError,
- )
- from controllers.console.datasets.error import DatasetNotInitializedError
- from core.errors.error import (
- LLMBadRequestError,
- ModelCurrentlyNotSupportError,
- ProviderTokenNotInitError,
- QuotaExceededError,
- )
- from core.model_runtime.errors.invoke import InvokeError
- from fields.hit_testing_fields import hit_testing_record_fields
- from services.dataset_service import DatasetService
- from services.hit_testing_service import HitTestingService
- class DatasetsHitTestingBase:
- @staticmethod
- def get_and_validate_dataset(dataset_id: str):
- dataset = DatasetService.get_dataset(dataset_id)
- if dataset is None:
- raise NotFound("Dataset not found.")
- try:
- DatasetService.check_dataset_permission(dataset, current_user)
- except services.errors.account.NoPermissionError as e:
- raise Forbidden(str(e))
- return dataset
- @staticmethod
- def hit_testing_args_check(args):
- HitTestingService.hit_testing_args_check(args)
- @staticmethod
- def parse_args():
- parser = reqparse.RequestParser()
- parser.add_argument("query", type=str, location="json")
- parser.add_argument("retrieval_model", type=dict, required=False, location="json")
- parser.add_argument("external_retrieval_model", type=dict, required=False, location="json")
- return parser.parse_args()
- @staticmethod
- def perform_hit_testing(dataset, args):
- try:
- response = HitTestingService.retrieve(
- dataset=dataset,
- query=args["query"],
- account=current_user,
- retrieval_model=args["retrieval_model"],
- external_retrieval_model=args["external_retrieval_model"],
- limit=10,
- )
- return {"query": response["query"], "records": marshal(response["records"], hit_testing_record_fields)}
- except services.errors.index.IndexNotInitializedError:
- raise DatasetNotInitializedError()
- except ProviderTokenNotInitError as ex:
- raise ProviderNotInitializeError(ex.description)
- except QuotaExceededError:
- raise ProviderQuotaExceededError()
- except ModelCurrentlyNotSupportError:
- raise ProviderModelCurrentlyNotSupportError()
- except LLMBadRequestError:
- raise ProviderNotInitializeError(
- "No Embedding Model or Reranking Model available. Please configure a valid provider "
- "in the Settings -> Model Provider."
- )
- except InvokeError as e:
- raise CompletionRequestError(e.description)
- except ValueError as e:
- raise ValueError(str(e))
- except Exception as e:
- logging.exception("Hit testing failed.")
- raise InternalServerError(str(e))
|