Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

message.py 7.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. import logging
  2. from flask_restx import marshal_with, reqparse
  3. from flask_restx.inputs import int_range
  4. from werkzeug.exceptions import InternalServerError, NotFound
  5. from controllers.console.app.error import (
  6. AppMoreLikeThisDisabledError,
  7. CompletionRequestError,
  8. ProviderModelCurrentlyNotSupportError,
  9. ProviderNotInitializeError,
  10. ProviderQuotaExceededError,
  11. )
  12. from controllers.console.explore.error import (
  13. AppSuggestedQuestionsAfterAnswerDisabledError,
  14. NotChatAppError,
  15. NotCompletionAppError,
  16. )
  17. from controllers.console.explore.wraps import InstalledAppResource
  18. from core.app.entities.app_invoke_entities import InvokeFrom
  19. from core.errors.error import ModelCurrentlyNotSupportError, ProviderTokenNotInitError, QuotaExceededError
  20. from core.model_runtime.errors.invoke import InvokeError
  21. from fields.message_fields import message_infinite_scroll_pagination_fields
  22. from libs import helper
  23. from libs.helper import uuid_value
  24. from libs.login import current_user
  25. from models import Account
  26. from models.model import AppMode
  27. from services.app_generate_service import AppGenerateService
  28. from services.errors.app import MoreLikeThisDisabledError
  29. from services.errors.conversation import ConversationNotExistsError
  30. from services.errors.message import (
  31. FirstMessageNotExistsError,
  32. MessageNotExistsError,
  33. SuggestedQuestionsAfterAnswerDisabledError,
  34. )
  35. from services.message_service import MessageService
  36. from .. import console_ns
  37. logger = logging.getLogger(__name__)
  38. @console_ns.route(
  39. "/installed-apps/<uuid:installed_app_id>/messages",
  40. endpoint="installed_app_messages",
  41. )
  42. class MessageListApi(InstalledAppResource):
  43. @marshal_with(message_infinite_scroll_pagination_fields)
  44. def get(self, installed_app):
  45. app_model = installed_app.app
  46. app_mode = AppMode.value_of(app_model.mode)
  47. if app_mode not in {AppMode.CHAT, AppMode.AGENT_CHAT, AppMode.ADVANCED_CHAT}:
  48. raise NotChatAppError()
  49. parser = reqparse.RequestParser()
  50. parser.add_argument("conversation_id", required=True, type=uuid_value, location="args")
  51. parser.add_argument("first_id", type=uuid_value, location="args")
  52. parser.add_argument("limit", type=int_range(1, 100), required=False, default=20, location="args")
  53. args = parser.parse_args()
  54. try:
  55. if not isinstance(current_user, Account):
  56. raise ValueError("current_user must be an Account instance")
  57. return MessageService.pagination_by_first_id(
  58. app_model, current_user, args["conversation_id"], args["first_id"], args["limit"]
  59. )
  60. except ConversationNotExistsError:
  61. raise NotFound("Conversation Not Exists.")
  62. except FirstMessageNotExistsError:
  63. raise NotFound("First Message Not Exists.")
  64. @console_ns.route(
  65. "/installed-apps/<uuid:installed_app_id>/messages/<uuid:message_id>/feedbacks",
  66. endpoint="installed_app_message_feedback",
  67. )
  68. class MessageFeedbackApi(InstalledAppResource):
  69. def post(self, installed_app, message_id):
  70. app_model = installed_app.app
  71. message_id = str(message_id)
  72. parser = reqparse.RequestParser()
  73. parser.add_argument("rating", type=str, choices=["like", "dislike", None], location="json")
  74. parser.add_argument("content", type=str, location="json")
  75. args = parser.parse_args()
  76. try:
  77. if not isinstance(current_user, Account):
  78. raise ValueError("current_user must be an Account instance")
  79. MessageService.create_feedback(
  80. app_model=app_model,
  81. message_id=message_id,
  82. user=current_user,
  83. rating=args.get("rating"),
  84. content=args.get("content"),
  85. )
  86. except MessageNotExistsError:
  87. raise NotFound("Message Not Exists.")
  88. return {"result": "success"}
  89. @console_ns.route(
  90. "/installed-apps/<uuid:installed_app_id>/messages/<uuid:message_id>/more-like-this",
  91. endpoint="installed_app_more_like_this",
  92. )
  93. class MessageMoreLikeThisApi(InstalledAppResource):
  94. def get(self, installed_app, message_id):
  95. app_model = installed_app.app
  96. if app_model.mode != "completion":
  97. raise NotCompletionAppError()
  98. message_id = str(message_id)
  99. parser = reqparse.RequestParser()
  100. parser.add_argument(
  101. "response_mode", type=str, required=True, choices=["blocking", "streaming"], location="args"
  102. )
  103. args = parser.parse_args()
  104. streaming = args["response_mode"] == "streaming"
  105. try:
  106. if not isinstance(current_user, Account):
  107. raise ValueError("current_user must be an Account instance")
  108. response = AppGenerateService.generate_more_like_this(
  109. app_model=app_model,
  110. user=current_user,
  111. message_id=message_id,
  112. invoke_from=InvokeFrom.EXPLORE,
  113. streaming=streaming,
  114. )
  115. return helper.compact_generate_response(response)
  116. except MessageNotExistsError:
  117. raise NotFound("Message Not Exists.")
  118. except MoreLikeThisDisabledError:
  119. raise AppMoreLikeThisDisabledError()
  120. except ProviderTokenNotInitError as ex:
  121. raise ProviderNotInitializeError(ex.description)
  122. except QuotaExceededError:
  123. raise ProviderQuotaExceededError()
  124. except ModelCurrentlyNotSupportError:
  125. raise ProviderModelCurrentlyNotSupportError()
  126. except InvokeError as e:
  127. raise CompletionRequestError(e.description)
  128. except ValueError as e:
  129. raise e
  130. except Exception:
  131. logger.exception("internal server error.")
  132. raise InternalServerError()
  133. @console_ns.route(
  134. "/installed-apps/<uuid:installed_app_id>/messages/<uuid:message_id>/suggested-questions",
  135. endpoint="installed_app_suggested_question",
  136. )
  137. class MessageSuggestedQuestionApi(InstalledAppResource):
  138. def get(self, installed_app, message_id):
  139. app_model = installed_app.app
  140. app_mode = AppMode.value_of(app_model.mode)
  141. if app_mode not in {AppMode.CHAT, AppMode.AGENT_CHAT, AppMode.ADVANCED_CHAT}:
  142. raise NotChatAppError()
  143. message_id = str(message_id)
  144. try:
  145. if not isinstance(current_user, Account):
  146. raise ValueError("current_user must be an Account instance")
  147. questions = MessageService.get_suggested_questions_after_answer(
  148. app_model=app_model, user=current_user, message_id=message_id, invoke_from=InvokeFrom.EXPLORE
  149. )
  150. except MessageNotExistsError:
  151. raise NotFound("Message not found")
  152. except ConversationNotExistsError:
  153. raise NotFound("Conversation not found")
  154. except SuggestedQuestionsAfterAnswerDisabledError:
  155. raise AppSuggestedQuestionsAfterAnswerDisabledError()
  156. except ProviderTokenNotInitError as ex:
  157. raise ProviderNotInitializeError(ex.description)
  158. except QuotaExceededError:
  159. raise ProviderQuotaExceededError()
  160. except ModelCurrentlyNotSupportError:
  161. raise ProviderModelCurrentlyNotSupportError()
  162. except InvokeError as e:
  163. raise CompletionRequestError(e.description)
  164. except Exception:
  165. logger.exception("internal server error.")
  166. raise InternalServerError()
  167. return {"data": questions}