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.
		
		
		
		
			
				
					195 lines
				
				8.1 KiB
			
		
		
			
		
	
	
					195 lines
				
				8.1 KiB
			| 
											1 year ago
										 | from datetime import datetime | ||
| 
											1 year ago
										 | from fastapi import APIRouter, Depends, Form, Request | ||
| 
											1 year ago
										 | from pydantic_validation_decorator import ValidateFields | ||
| 
											1 year ago
										 | from sqlalchemy.ext.asyncio import AsyncSession | ||
|  | from config.enums import BusinessType | ||
| 
											2 years ago
										 | from config.get_db import get_db | ||
| 
											1 year ago
										 | from module_admin.annotation.log_annotation import Log | ||
| 
											1 year ago
										 | from module_admin.aspect.interface_auth import CheckUserInterfaceAuth | ||
|  | from module_admin.entity.vo.job_vo import ( | ||
|  |     DeleteJobLogModel, | ||
|  |     DeleteJobModel, | ||
|  |     EditJobModel, | ||
|  |     JobLogPageQueryModel, | ||
|  |     JobModel, | ||
|  |     JobPageQueryModel, | ||
|  | ) | ||
|  | from module_admin.entity.vo.user_vo import CurrentUserModel | ||
|  | from module_admin.service.job_log_service import JobLogService | ||
|  | from module_admin.service.job_service import JobService | ||
|  | from module_admin.service.login_service import LoginService | ||
| 
											2 years ago
										 | from utils.common_util import bytes2file_response | ||
| 
											1 year ago
										 | from utils.log_util import logger | ||
|  | from utils.page_util import PageResponseModel | ||
|  | from utils.response_util import ResponseUtil | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
|  | jobController = APIRouter(prefix='/monitor', dependencies=[Depends(LoginService.get_current_user)]) | ||
|  | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.get( | ||
|  |     '/job/list', response_model=PageResponseModel, dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:list'))] | ||
|  | ) | ||
|  | async def get_system_job_list( | ||
|  |     request: Request, | ||
| 
											1 year ago
										 |     job_page_query: JobPageQueryModel = Depends(JobPageQueryModel.as_query), | ||
| 
											1 year ago
										 |     query_db: AsyncSession = Depends(get_db), | ||
|  | ): | ||
| 
											1 year ago
										 |     # 获取分页数据 | ||
|  |     notice_page_query_result = await JobService.get_job_list_services(query_db, job_page_query, is_page=True) | ||
|  |     logger.info('获取成功') | ||
|  | 
 | ||
|  |     return ResponseUtil.success(model_content=notice_page_query_result) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.post('/job', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:add'))]) | ||
| 
											1 year ago
										 | @ValidateFields(validate_model='add_job') | ||
| 
											1 year ago
										 | @Log(title='定时任务', business_type=BusinessType.INSERT) | ||
| 
											1 year ago
										 | async def add_system_job( | ||
|  |     request: Request, | ||
|  |     add_job: JobModel, | ||
|  |     query_db: AsyncSession = Depends(get_db), | ||
|  |     current_user: CurrentUserModel = Depends(LoginService.get_current_user), | ||
|  | ): | ||
| 
											1 year ago
										 |     add_job.create_by = current_user.user.user_name | ||
|  |     add_job.create_time = datetime.now() | ||
|  |     add_job.update_by = current_user.user.user_name | ||
|  |     add_job.update_time = datetime.now() | ||
|  |     add_job_result = await JobService.add_job_services(query_db, add_job) | ||
|  |     logger.info(add_job_result.message) | ||
|  | 
 | ||
|  |     return ResponseUtil.success(msg=add_job_result.message) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.put('/job', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:edit'))]) | ||
| 
											1 year ago
										 | @ValidateFields(validate_model='edit_job') | ||
| 
											1 year ago
										 | @Log(title='定时任务', business_type=BusinessType.UPDATE) | ||
| 
											1 year ago
										 | async def edit_system_job( | ||
|  |     request: Request, | ||
|  |     edit_job: EditJobModel, | ||
|  |     query_db: AsyncSession = Depends(get_db), | ||
|  |     current_user: CurrentUserModel = Depends(LoginService.get_current_user), | ||
|  | ): | ||
| 
											1 year ago
										 |     edit_job.update_by = current_user.user.user_name | ||
|  |     edit_job.update_time = datetime.now() | ||
|  |     edit_job_result = await JobService.edit_job_services(query_db, edit_job) | ||
|  |     logger.info(edit_job_result.message) | ||
|  | 
 | ||
|  |     return ResponseUtil.success(msg=edit_job_result.message) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.put('/job/changeStatus', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:changeStatus'))]) | ||
| 
											1 year ago
										 | @Log(title='定时任务', business_type=BusinessType.UPDATE) | ||
| 
											1 year ago
										 | async def change_system_job_status( | ||
|  |     request: Request, | ||
| 
											1 year ago
										 |     change_job: EditJobModel, | ||
| 
											1 year ago
										 |     query_db: AsyncSession = Depends(get_db), | ||
|  |     current_user: CurrentUserModel = Depends(LoginService.get_current_user), | ||
|  | ): | ||
| 
											1 year ago
										 |     edit_job = EditJobModel( | ||
|  |         jobId=change_job.job_id, | ||
|  |         status=change_job.status, | ||
|  |         updateBy=current_user.user.user_name, | ||
|  |         updateTime=datetime.now(), | ||
|  |         type='status', | ||
|  |     ) | ||
|  |     edit_job_result = await JobService.edit_job_services(query_db, edit_job) | ||
|  |     logger.info(edit_job_result.message) | ||
|  | 
 | ||
|  |     return ResponseUtil.success(msg=edit_job_result.message) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.put('/job/run', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:changeStatus'))]) | ||
| 
											1 year ago
										 | @Log(title='定时任务', business_type=BusinessType.UPDATE) | ||
| 
											1 year ago
										 | async def execute_system_job(request: Request, execute_job: JobModel, query_db: AsyncSession = Depends(get_db)): | ||
| 
											1 year ago
										 |     execute_job_result = await JobService.execute_job_once_services(query_db, execute_job) | ||
|  |     logger.info(execute_job_result.message) | ||
|  | 
 | ||
|  |     return ResponseUtil.success(msg=execute_job_result.message) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.delete('/job/{job_ids}', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:remove'))]) | ||
| 
											1 year ago
										 | @Log(title='定时任务', business_type=BusinessType.DELETE) | ||
| 
											1 year ago
										 | async def delete_system_job(request: Request, job_ids: str, query_db: AsyncSession = Depends(get_db)): | ||
| 
											1 year ago
										 |     delete_job = DeleteJobModel(jobIds=job_ids) | ||
|  |     delete_job_result = await JobService.delete_job_services(query_db, delete_job) | ||
|  |     logger.info(delete_job_result.message) | ||
|  | 
 | ||
|  |     return ResponseUtil.success(msg=delete_job_result.message) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.get( | ||
|  |     '/job/{job_id}', response_model=JobModel, dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:query'))] | ||
|  | ) | ||
| 
											1 year ago
										 | async def query_detail_system_job(request: Request, job_id: int, query_db: AsyncSession = Depends(get_db)): | ||
| 
											1 year ago
										 |     job_detail_result = await JobService.job_detail_services(query_db, job_id) | ||
|  |     logger.info(f'获取job_id为{job_id}的信息成功') | ||
|  | 
 | ||
|  |     return ResponseUtil.success(data=job_detail_result) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.post('/job/export', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:export'))]) | ||
| 
											1 year ago
										 | @Log(title='定时任务', business_type=BusinessType.EXPORT) | ||
| 
											1 year ago
										 | async def export_system_job_list( | ||
|  |     request: Request, | ||
| 
											1 year ago
										 |     job_page_query: JobPageQueryModel = Form(), | ||
| 
											1 year ago
										 |     query_db: AsyncSession = Depends(get_db), | ||
|  | ): | ||
| 
											1 year ago
										 |     # 获取全量数据 | ||
|  |     job_query_result = await JobService.get_job_list_services(query_db, job_page_query, is_page=False) | ||
|  |     job_export_result = await JobService.export_job_list_services(request, job_query_result) | ||
|  |     logger.info('导出成功') | ||
|  | 
 | ||
|  |     return ResponseUtil.streaming(data=bytes2file_response(job_export_result)) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.get( | ||
|  |     '/jobLog/list', response_model=PageResponseModel, dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:list'))] | ||
|  | ) | ||
|  | async def get_system_job_log_list( | ||
|  |     request: Request, | ||
| 
											1 year ago
										 |     job_log_page_query: JobLogPageQueryModel = Depends(JobLogPageQueryModel.as_query), | ||
| 
											1 year ago
										 |     query_db: AsyncSession = Depends(get_db), | ||
|  | ): | ||
| 
											1 year ago
										 |     # 获取分页数据 | ||
|  |     job_log_page_query_result = await JobLogService.get_job_log_list_services( | ||
|  |         query_db, job_log_page_query, is_page=True | ||
|  |     ) | ||
|  |     logger.info('获取成功') | ||
|  | 
 | ||
|  |     return ResponseUtil.success(model_content=job_log_page_query_result) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.delete('/jobLog/clean', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:remove'))]) | ||
| 
											1 year ago
										 | @Log(title='定时任务调度日志', business_type=BusinessType.CLEAN) | ||
| 
											1 year ago
										 | async def clear_system_job_log(request: Request, query_db: AsyncSession = Depends(get_db)): | ||
| 
											1 year ago
										 |     clear_job_log_result = await JobLogService.clear_job_log_services(query_db) | ||
|  |     logger.info(clear_job_log_result.message) | ||
|  | 
 | ||
|  |     return ResponseUtil.success(msg=clear_job_log_result.message) | ||
| 
											1 year ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.delete('/jobLog/{job_log_ids}', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:remove'))]) | ||
| 
											1 year ago
										 | @Log(title='定时任务调度日志', business_type=BusinessType.DELETE) | ||
| 
											1 year ago
										 | async def delete_system_job_log(request: Request, job_log_ids: str, query_db: AsyncSession = Depends(get_db)): | ||
| 
											1 year ago
										 |     delete_job_log = DeleteJobLogModel(jobLogIds=job_log_ids) | ||
|  |     delete_job_log_result = await JobLogService.delete_job_log_services(query_db, delete_job_log) | ||
|  |     logger.info(delete_job_log_result.message) | ||
|  | 
 | ||
|  |     return ResponseUtil.success(msg=delete_job_log_result.message) | ||
| 
											2 years ago
										 | 
 | ||
|  | 
 | ||
| 
											1 year ago
										 | @jobController.post('/jobLog/export', dependencies=[Depends(CheckUserInterfaceAuth('monitor:job:export'))]) | ||
| 
											1 year ago
										 | @Log(title='定时任务调度日志', business_type=BusinessType.EXPORT) | ||
| 
											1 year ago
										 | async def export_system_job_log_list( | ||
|  |     request: Request, | ||
| 
											1 year ago
										 |     job_log_page_query: JobLogPageQueryModel = Form(), | ||
| 
											1 year ago
										 |     query_db: AsyncSession = Depends(get_db), | ||
|  | ): | ||
| 
											1 year ago
										 |     # 获取全量数据 | ||
|  |     job_log_query_result = await JobLogService.get_job_log_list_services(query_db, job_log_page_query, is_page=False) | ||
|  |     job_log_export_result = await JobLogService.export_job_log_list_services(request, job_log_query_result) | ||
|  |     logger.info('导出成功') | ||
|  | 
 | ||
|  |     return ResponseUtil.streaming(data=bytes2file_response(job_log_export_result)) |