workflow.py 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. import logging
  2. from flask_restful import reqparse # type: ignore
  3. from werkzeug.exceptions import InternalServerError
  4. from controllers.web import api
  5. from controllers.web.error import (
  6. CompletionRequestError,
  7. NotWorkflowAppError,
  8. ProviderModelCurrentlyNotSupportError,
  9. ProviderNotInitializeError,
  10. ProviderQuotaExceededError,
  11. )
  12. from controllers.web.wraps import WebApiResource
  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 models.model import App, AppMode, EndUser
  23. from services.app_generate_service import AppGenerateService
  24. logger = logging.getLogger(__name__)
  25. class WorkflowRunApi(WebApiResource):
  26. def post(self, app_model: App, end_user: EndUser):
  27. """
  28. Run workflow
  29. """
  30. app_mode = AppMode.value_of(app_model.mode)
  31. if app_mode != AppMode.WORKFLOW:
  32. raise NotWorkflowAppError()
  33. parser = reqparse.RequestParser()
  34. parser.add_argument("inputs", type=dict, required=True, nullable=False, location="json")
  35. parser.add_argument("files", type=list, required=False, location="json")
  36. args = parser.parse_args()
  37. try:
  38. response = AppGenerateService.generate(
  39. app_model=app_model, user=end_user, args=args, invoke_from=InvokeFrom.WEB_APP, streaming=True
  40. )
  41. return helper.compact_generate_response(response)
  42. except ProviderTokenNotInitError as ex:
  43. raise ProviderNotInitializeError(ex.description)
  44. except QuotaExceededError:
  45. raise ProviderQuotaExceededError()
  46. except ModelCurrentlyNotSupportError:
  47. raise ProviderModelCurrentlyNotSupportError()
  48. except InvokeError as e:
  49. raise CompletionRequestError(e.description)
  50. except ValueError as e:
  51. raise e
  52. except Exception as e:
  53. logging.exception("internal server error.")
  54. raise InternalServerError()
  55. class WorkflowTaskStopApi(WebApiResource):
  56. def post(self, app_model: App, end_user: EndUser, task_id: str):
  57. """
  58. Stop workflow task
  59. """
  60. app_mode = AppMode.value_of(app_model.mode)
  61. if app_mode != AppMode.WORKFLOW:
  62. raise NotWorkflowAppError()
  63. AppQueueManager.set_stop_flag(task_id, InvokeFrom.WEB_APP, end_user.id)
  64. return {"result": "success"}
  65. api.add_resource(WorkflowRunApi, "/workflows/run")
  66. api.add_resource(WorkflowTaskStopApi, "/workflows/tasks/<string:task_id>/stop")