您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

workflow.py 3.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. import logging
  2. from flask_restx import reqparse
  3. from werkzeug.exceptions import InternalServerError
  4. from controllers.console.app.error import (
  5. CompletionRequestError,
  6. ProviderModelCurrentlyNotSupportError,
  7. ProviderNotInitializeError,
  8. ProviderQuotaExceededError,
  9. )
  10. from controllers.console.explore.error import NotWorkflowAppError
  11. from controllers.console.explore.wraps import InstalledAppResource
  12. from controllers.web.error import InvokeRateLimitError as InvokeRateLimitHttpError
  13. from core.app.apps.base_app_queue_manager import AppQueueManager
  14. from core.app.entities.app_invoke_entities import InvokeFrom
  15. from core.errors.error import (
  16. ModelCurrentlyNotSupportError,
  17. ProviderTokenNotInitError,
  18. QuotaExceededError,
  19. )
  20. from core.model_runtime.errors.invoke import InvokeError
  21. from libs import helper
  22. from libs.login import current_user
  23. from models.model import AppMode, InstalledApp
  24. from services.app_generate_service import AppGenerateService
  25. from services.errors.llm import InvokeRateLimitError
  26. logger = logging.getLogger(__name__)
  27. class InstalledAppWorkflowRunApi(InstalledAppResource):
  28. def post(self, installed_app: InstalledApp):
  29. """
  30. Run workflow
  31. """
  32. app_model = installed_app.app
  33. if not app_model:
  34. raise NotWorkflowAppError()
  35. app_mode = AppMode.value_of(app_model.mode)
  36. if app_mode != AppMode.WORKFLOW:
  37. raise NotWorkflowAppError()
  38. parser = reqparse.RequestParser()
  39. parser.add_argument("inputs", type=dict, required=True, nullable=False, location="json")
  40. parser.add_argument("files", type=list, required=False, location="json")
  41. args = parser.parse_args()
  42. assert current_user is not None
  43. try:
  44. response = AppGenerateService.generate(
  45. app_model=app_model, user=current_user, args=args, invoke_from=InvokeFrom.EXPLORE, streaming=True
  46. )
  47. return helper.compact_generate_response(response)
  48. except ProviderTokenNotInitError as ex:
  49. raise ProviderNotInitializeError(ex.description)
  50. except QuotaExceededError:
  51. raise ProviderQuotaExceededError()
  52. except ModelCurrentlyNotSupportError:
  53. raise ProviderModelCurrentlyNotSupportError()
  54. except InvokeError as e:
  55. raise CompletionRequestError(e.description)
  56. except InvokeRateLimitError as ex:
  57. raise InvokeRateLimitHttpError(ex.description)
  58. except ValueError as e:
  59. raise e
  60. except Exception:
  61. logger.exception("internal server error.")
  62. raise InternalServerError()
  63. class InstalledAppWorkflowTaskStopApi(InstalledAppResource):
  64. def post(self, installed_app: InstalledApp, task_id: str):
  65. """
  66. Stop workflow task
  67. """
  68. app_model = installed_app.app
  69. if not app_model:
  70. raise NotWorkflowAppError()
  71. app_mode = AppMode.value_of(app_model.mode)
  72. if app_mode != AppMode.WORKFLOW:
  73. raise NotWorkflowAppError()
  74. assert current_user is not None
  75. AppQueueManager.set_stop_flag(task_id, InvokeFrom.EXPLORE, current_user.id)
  76. return {"result": "success"}