conversation.py 3.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. from flask_restful import Resource, marshal_with, reqparse
  2. from flask_restful.inputs import int_range
  3. from werkzeug.exceptions import NotFound
  4. import services
  5. from controllers.service_api import api
  6. from controllers.service_api.app.error import NotChatAppError
  7. from controllers.service_api.wraps import FetchUserArg, WhereisUserArg, validate_app_token
  8. from core.app.entities.app_invoke_entities import InvokeFrom
  9. from fields.conversation_fields import conversation_infinite_scroll_pagination_fields, simple_conversation_fields
  10. from libs.helper import uuid_value
  11. from models.model import App, AppMode, EndUser
  12. from services.conversation_service import ConversationService
  13. class ConversationApi(Resource):
  14. @validate_app_token(fetch_user_arg=FetchUserArg(fetch_from=WhereisUserArg.QUERY))
  15. @marshal_with(conversation_infinite_scroll_pagination_fields)
  16. def get(self, app_model: App, end_user: EndUser):
  17. app_mode = AppMode.value_of(app_model.mode)
  18. if app_mode not in [AppMode.CHAT, AppMode.AGENT_CHAT, AppMode.ADVANCED_CHAT]:
  19. raise NotChatAppError()
  20. parser = reqparse.RequestParser()
  21. parser.add_argument("last_id", type=uuid_value, location="args")
  22. parser.add_argument("limit", type=int_range(1, 100), required=False, default=20, location="args")
  23. parser.add_argument(
  24. "sort_by",
  25. type=str,
  26. choices=["created_at", "-created_at", "updated_at", "-updated_at"],
  27. required=False,
  28. default="-updated_at",
  29. location="args",
  30. )
  31. args = parser.parse_args()
  32. try:
  33. return ConversationService.pagination_by_last_id(
  34. app_model=app_model,
  35. user=end_user,
  36. last_id=args["last_id"],
  37. limit=args["limit"],
  38. invoke_from=InvokeFrom.SERVICE_API,
  39. sort_by=args["sort_by"],
  40. )
  41. except services.errors.conversation.LastConversationNotExistsError:
  42. raise NotFound("Last Conversation Not Exists.")
  43. class ConversationDetailApi(Resource):
  44. @validate_app_token(fetch_user_arg=FetchUserArg(fetch_from=WhereisUserArg.JSON))
  45. @marshal_with(simple_conversation_fields)
  46. def delete(self, app_model: App, end_user: EndUser, c_id):
  47. app_mode = AppMode.value_of(app_model.mode)
  48. if app_mode not in [AppMode.CHAT, AppMode.AGENT_CHAT, AppMode.ADVANCED_CHAT]:
  49. raise NotChatAppError()
  50. conversation_id = str(c_id)
  51. try:
  52. ConversationService.delete(app_model, conversation_id, end_user)
  53. except services.errors.conversation.ConversationNotExistsError:
  54. raise NotFound("Conversation Not Exists.")
  55. return {"result": "success"}, 200
  56. class ConversationRenameApi(Resource):
  57. @validate_app_token(fetch_user_arg=FetchUserArg(fetch_from=WhereisUserArg.JSON))
  58. @marshal_with(simple_conversation_fields)
  59. def post(self, app_model: App, end_user: EndUser, c_id):
  60. app_mode = AppMode.value_of(app_model.mode)
  61. if app_mode not in [AppMode.CHAT, AppMode.AGENT_CHAT, AppMode.ADVANCED_CHAT]:
  62. raise NotChatAppError()
  63. conversation_id = str(c_id)
  64. parser = reqparse.RequestParser()
  65. parser.add_argument("name", type=str, required=False, location="json")
  66. parser.add_argument("auto_generate", type=bool, required=False, default=False, location="json")
  67. args = parser.parse_args()
  68. try:
  69. return ConversationService.rename(app_model, conversation_id, end_user, args["name"], args["auto_generate"])
  70. except services.errors.conversation.ConversationNotExistsError:
  71. raise NotFound("Conversation Not Exists.")
  72. api.add_resource(ConversationRenameApi, "/conversations/<uuid:c_id>/name", endpoint="conversation_name")
  73. api.add_resource(ConversationApi, "/conversations")
  74. api.add_resource(ConversationDetailApi, "/conversations/<uuid:c_id>", endpoint="conversation_detail")