| 
									
										
										
										
											2025-04-16 19:21:18 +08:00
										 |  |  | from dateutil.parser import isoparse | 
					
						
							| 
									
										
										
										
											2025-05-06 11:58:49 +08:00
										 |  |  | from flask_restful import Resource, marshal_with, reqparse | 
					
						
							|  |  |  | from flask_restful.inputs import int_range | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  | from sqlalchemy.orm import Session | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | from controllers.console import api | 
					
						
							|  |  |  | from controllers.console.app.wraps import get_app_model | 
					
						
							| 
									
										
										
										
											2024-11-01 15:51:22 +08:00
										 |  |  | from controllers.console.wraps import account_initialization_required, setup_required | 
					
						
							| 
									
										
										
										
											2025-05-30 04:34:13 +08:00
										 |  |  | from core.workflow.entities.workflow_execution import WorkflowExecutionStatus | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  | from extensions.ext_database import db | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | from fields.workflow_app_log_fields import workflow_app_log_pagination_fields | 
					
						
							|  |  |  | from libs.login import login_required | 
					
						
							| 
									
										
										
										
											2024-10-21 10:43:49 +08:00
										 |  |  | from models import App | 
					
						
							|  |  |  | from models.model import AppMode | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | from services.workflow_app_service import WorkflowAppService | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class WorkflowAppLogApi(Resource): | 
					
						
							|  |  |  |     @setup_required | 
					
						
							|  |  |  |     @login_required | 
					
						
							|  |  |  |     @account_initialization_required | 
					
						
							|  |  |  |     @get_app_model(mode=[AppMode.WORKFLOW]) | 
					
						
							|  |  |  |     @marshal_with(workflow_app_log_pagination_fields) | 
					
						
							|  |  |  |     def get(self, app_model: App): | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         Get workflow app logs | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         parser = reqparse.RequestParser() | 
					
						
							| 
									
										
										
										
											2024-08-26 15:29:10 +08:00
										 |  |  |         parser.add_argument("keyword", type=str, location="args") | 
					
						
							|  |  |  |         parser.add_argument("status", type=str, choices=["succeeded", "failed", "stopped"], location="args") | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  |         parser.add_argument( | 
					
						
							|  |  |  |             "created_at__before", type=str, location="args", help="Filter logs created before this timestamp" | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |         parser.add_argument( | 
					
						
							|  |  |  |             "created_at__after", type=str, location="args", help="Filter logs created after this timestamp" | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2024-08-26 15:29:10 +08:00
										 |  |  |         parser.add_argument("page", type=int_range(1, 99999), default=1, location="args") | 
					
						
							|  |  |  |         parser.add_argument("limit", type=int_range(1, 100), default=20, location="args") | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         args = parser.parse_args() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-30 04:34:13 +08:00
										 |  |  |         args.status = WorkflowExecutionStatus(args.status) if args.status else None | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  |         if args.created_at__before: | 
					
						
							| 
									
										
										
										
											2025-04-16 19:21:18 +08:00
										 |  |  |             args.created_at__before = isoparse(args.created_at__before) | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if args.created_at__after: | 
					
						
							| 
									
										
										
										
											2025-04-16 19:21:18 +08:00
										 |  |  |             args.created_at__after = isoparse(args.created_at__after) | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         # get paginate workflow app logs | 
					
						
							|  |  |  |         workflow_app_service = WorkflowAppService() | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  |         with Session(db.engine) as session: | 
					
						
							|  |  |  |             workflow_app_log_pagination = workflow_app_service.get_paginate_workflow_app_logs( | 
					
						
							|  |  |  |                 session=session, | 
					
						
							|  |  |  |                 app_model=app_model, | 
					
						
							|  |  |  |                 keyword=args.keyword, | 
					
						
							|  |  |  |                 status=args.status, | 
					
						
							|  |  |  |                 created_at_before=args.created_at__before, | 
					
						
							|  |  |  |                 created_at_after=args.created_at__after, | 
					
						
							|  |  |  |                 page=args.page, | 
					
						
							|  |  |  |                 limit=args.limit, | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-10 14:02:58 +08:00
										 |  |  |             return workflow_app_log_pagination | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-26 15:29:10 +08:00
										 |  |  | api.add_resource(WorkflowAppLogApi, "/apps/<uuid:app_id>/workflow-app-logs") |