conversation.py 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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. return ConversationService.delete(app_model, conversation_id, end_user)
  53. except services.errors.conversation.ConversationNotExistsError:
  54. raise NotFound("Conversation Not Exists.")
  55. class ConversationRenameApi(Resource):
  56. @validate_app_token(fetch_user_arg=FetchUserArg(fetch_from=WhereisUserArg.JSON))
  57. @marshal_with(simple_conversation_fields)
  58. def post(self, app_model: App, end_user: EndUser, c_id):
  59. app_mode = AppMode.value_of(app_model.mode)
  60. if app_mode not in {AppMode.CHAT, AppMode.AGENT_CHAT, AppMode.ADVANCED_CHAT}:
  61. raise NotChatAppError()
  62. conversation_id = str(c_id)
  63. parser = reqparse.RequestParser()
  64. parser.add_argument("name", type=str, required=False, location="json")
  65. parser.add_argument("auto_generate", type=bool, required=False, default=False, location="json")
  66. args = parser.parse_args()
  67. try:
  68. return ConversationService.rename(app_model, conversation_id, end_user, args["name"], args["auto_generate"])
  69. except services.errors.conversation.ConversationNotExistsError:
  70. raise NotFound("Conversation Not Exists.")
  71. api.add_resource(ConversationRenameApi, "/conversations/<uuid:c_id>/name", endpoint="conversation_name")
  72. api.add_resource(ConversationApi, "/conversations")
  73. api.add_resource(ConversationDetailApi, "/conversations/<uuid:c_id>", endpoint="conversation_detail")