You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

workflow.py 3.6KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  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 core.workflow.graph_engine.manager import GraphEngineManager
  22. from libs import helper
  23. from libs.login import current_user
  24. from models.model import AppMode, InstalledApp
  25. from services.app_generate_service import AppGenerateService
  26. from services.errors.llm import InvokeRateLimitError
  27. from .. import console_ns
  28. logger = logging.getLogger(__name__)
  29. @console_ns.route("/installed-apps/<uuid:installed_app_id>/workflows/run")
  30. class InstalledAppWorkflowRunApi(InstalledAppResource):
  31. def post(self, installed_app: InstalledApp):
  32. """
  33. Run workflow
  34. """
  35. app_model = installed_app.app
  36. if not app_model:
  37. raise NotWorkflowAppError()
  38. app_mode = AppMode.value_of(app_model.mode)
  39. if app_mode != AppMode.WORKFLOW:
  40. raise NotWorkflowAppError()
  41. parser = reqparse.RequestParser()
  42. parser.add_argument("inputs", type=dict, required=True, nullable=False, location="json")
  43. parser.add_argument("files", type=list, required=False, location="json")
  44. args = parser.parse_args()
  45. assert current_user is not None
  46. try:
  47. response = AppGenerateService.generate(
  48. app_model=app_model, user=current_user, args=args, invoke_from=InvokeFrom.EXPLORE, streaming=True
  49. )
  50. return helper.compact_generate_response(response)
  51. except ProviderTokenNotInitError as ex:
  52. raise ProviderNotInitializeError(ex.description)
  53. except QuotaExceededError:
  54. raise ProviderQuotaExceededError()
  55. except ModelCurrentlyNotSupportError:
  56. raise ProviderModelCurrentlyNotSupportError()
  57. except InvokeError as e:
  58. raise CompletionRequestError(e.description)
  59. except InvokeRateLimitError as ex:
  60. raise InvokeRateLimitHttpError(ex.description)
  61. except ValueError as e:
  62. raise e
  63. except Exception:
  64. logger.exception("internal server error.")
  65. raise InternalServerError()
  66. @console_ns.route("/installed-apps/<uuid:installed_app_id>/workflows/tasks/<string:task_id>/stop")
  67. class InstalledAppWorkflowTaskStopApi(InstalledAppResource):
  68. def post(self, installed_app: InstalledApp, task_id: str):
  69. """
  70. Stop workflow task
  71. """
  72. app_model = installed_app.app
  73. if not app_model:
  74. raise NotWorkflowAppError()
  75. app_mode = AppMode.value_of(app_model.mode)
  76. if app_mode != AppMode.WORKFLOW:
  77. raise NotWorkflowAppError()
  78. assert current_user is not None
  79. # Stop using both mechanisms for backward compatibility
  80. # Legacy stop flag mechanism (without user check)
  81. AppQueueManager.set_stop_flag_no_user_check(task_id)
  82. # New graph engine command channel mechanism
  83. GraphEngineManager.send_stop_command(task_id)
  84. return {"result": "success"}