workflow_app_log.py 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. from datetime import datetime
  2. from flask_restful import Resource, marshal_with, reqparse # type: ignore
  3. from flask_restful.inputs import int_range # type: ignore
  4. from sqlalchemy.orm import Session
  5. from controllers.console import api
  6. from controllers.console.app.wraps import get_app_model
  7. from controllers.console.wraps import account_initialization_required, setup_required
  8. from extensions.ext_database import db
  9. from fields.workflow_app_log_fields import workflow_app_log_pagination_fields
  10. from libs.login import login_required
  11. from models import App
  12. from models.model import AppMode
  13. from models.workflow import WorkflowRunStatus
  14. from services.workflow_app_service import WorkflowAppService
  15. class WorkflowAppLogApi(Resource):
  16. @setup_required
  17. @login_required
  18. @account_initialization_required
  19. @get_app_model(mode=[AppMode.WORKFLOW])
  20. @marshal_with(workflow_app_log_pagination_fields)
  21. def get(self, app_model: App):
  22. """
  23. Get workflow app logs
  24. """
  25. parser = reqparse.RequestParser()
  26. parser.add_argument("keyword", type=str, location="args")
  27. parser.add_argument("status", type=str, choices=["succeeded", "failed", "stopped"], location="args")
  28. parser.add_argument(
  29. "created_at__before", type=str, location="args", help="Filter logs created before this timestamp"
  30. )
  31. parser.add_argument(
  32. "created_at__after", type=str, location="args", help="Filter logs created after this timestamp"
  33. )
  34. parser.add_argument("page", type=int_range(1, 99999), default=1, location="args")
  35. parser.add_argument("limit", type=int_range(1, 100), default=20, location="args")
  36. args = parser.parse_args()
  37. args.status = WorkflowRunStatus(args.status) if args.status else None
  38. if args.created_at__before:
  39. args.created_at__before = datetime.fromisoformat(args.created_at__before.replace("Z", "+00:00"))
  40. if args.created_at__after:
  41. args.created_at__after = datetime.fromisoformat(args.created_at__after.replace("Z", "+00:00"))
  42. # get paginate workflow app logs
  43. workflow_app_service = WorkflowAppService()
  44. with Session(db.engine) as session:
  45. workflow_app_log_pagination = workflow_app_service.get_paginate_workflow_app_logs(
  46. session=session,
  47. app_model=app_model,
  48. keyword=args.keyword,
  49. status=args.status,
  50. created_at_before=args.created_at__before,
  51. created_at_after=args.created_at__after,
  52. page=args.page,
  53. limit=args.limit,
  54. )
  55. return workflow_app_log_pagination
  56. api.add_resource(WorkflowAppLogApi, "/apps/<uuid:app_id>/workflow-app-logs")