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_app_log.py 4.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. from dateutil.parser import isoparse
  2. from flask_restx import Resource, marshal_with, reqparse
  3. from flask_restx.inputs import int_range
  4. from sqlalchemy.orm import Session
  5. from controllers.console import api, console_ns
  6. from controllers.console.app.wraps import get_app_model
  7. from controllers.console.wraps import account_initialization_required, setup_required
  8. from core.workflow.entities.workflow_execution import WorkflowExecutionStatus
  9. from extensions.ext_database import db
  10. from fields.workflow_app_log_fields import workflow_app_log_pagination_fields
  11. from libs.login import login_required
  12. from models import App
  13. from models.model import AppMode
  14. from services.workflow_app_service import WorkflowAppService
  15. @console_ns.route("/apps/<uuid:app_id>/workflow-app-logs")
  16. class WorkflowAppLogApi(Resource):
  17. @api.doc("get_workflow_app_logs")
  18. @api.doc(description="Get workflow application execution logs")
  19. @api.doc(params={"app_id": "Application ID"})
  20. @api.doc(
  21. params={
  22. "keyword": "Search keyword for filtering logs",
  23. "status": "Filter by execution status (succeeded, failed, stopped, partial-succeeded)",
  24. "created_at__before": "Filter logs created before this timestamp",
  25. "created_at__after": "Filter logs created after this timestamp",
  26. "created_by_end_user_session_id": "Filter by end user session ID",
  27. "created_by_account": "Filter by account",
  28. "page": "Page number (1-99999)",
  29. "limit": "Number of items per page (1-100)",
  30. }
  31. )
  32. @api.response(200, "Workflow app logs retrieved successfully", workflow_app_log_pagination_fields)
  33. @setup_required
  34. @login_required
  35. @account_initialization_required
  36. @get_app_model(mode=[AppMode.WORKFLOW])
  37. @marshal_with(workflow_app_log_pagination_fields)
  38. def get(self, app_model: App):
  39. """
  40. Get workflow app logs
  41. """
  42. parser = reqparse.RequestParser()
  43. parser.add_argument("keyword", type=str, location="args")
  44. parser.add_argument(
  45. "status", type=str, choices=["succeeded", "failed", "stopped", "partial-succeeded"], location="args"
  46. )
  47. parser.add_argument(
  48. "created_at__before", type=str, location="args", help="Filter logs created before this timestamp"
  49. )
  50. parser.add_argument(
  51. "created_at__after", type=str, location="args", help="Filter logs created after this timestamp"
  52. )
  53. parser.add_argument(
  54. "created_by_end_user_session_id",
  55. type=str,
  56. location="args",
  57. required=False,
  58. default=None,
  59. )
  60. parser.add_argument(
  61. "created_by_account",
  62. type=str,
  63. location="args",
  64. required=False,
  65. default=None,
  66. )
  67. parser.add_argument("page", type=int_range(1, 99999), default=1, location="args")
  68. parser.add_argument("limit", type=int_range(1, 100), default=20, location="args")
  69. args = parser.parse_args()
  70. args.status = WorkflowExecutionStatus(args.status) if args.status else None
  71. if args.created_at__before:
  72. args.created_at__before = isoparse(args.created_at__before)
  73. if args.created_at__after:
  74. args.created_at__after = isoparse(args.created_at__after)
  75. # get paginate workflow app logs
  76. workflow_app_service = WorkflowAppService()
  77. with Session(db.engine) as session:
  78. workflow_app_log_pagination = workflow_app_service.get_paginate_workflow_app_logs(
  79. session=session,
  80. app_model=app_model,
  81. keyword=args.keyword,
  82. status=args.status,
  83. created_at_before=args.created_at__before,
  84. created_at_after=args.created_at__after,
  85. page=args.page,
  86. limit=args.limit,
  87. created_by_end_user_session_id=args.created_by_end_user_session_id,
  88. created_by_account=args.created_by_account,
  89. )
  90. return workflow_app_log_pagination