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.
		
		
		
		
			
				
					151 lines
				
				6.3 KiB
			
		
		
			
		
	
	
					151 lines
				
				6.3 KiB
			| 
								 
											1 year ago
										 
									 | 
							
								from fastapi import APIRouter, Depends, Form, Request
							 | 
						||
| 
								 
											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.log_vo import (
							 | 
						||
| 
								 | 
							
								    DeleteLoginLogModel,
							 | 
						||
| 
								 | 
							
								    DeleteOperLogModel,
							 | 
						||
| 
								 | 
							
								    LoginLogPageQueryModel,
							 | 
						||
| 
								 | 
							
								    OperLogPageQueryModel,
							 | 
						||
| 
								 | 
							
								    UnlockUser,
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								from module_admin.service.log_service import LoginLogService, OperationLogService
							 | 
						||
| 
								 | 
							
								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
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								logController = APIRouter(prefix='/monitor', dependencies=[Depends(LoginService.get_current_user)])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.get(
							 | 
						||
| 
								 | 
							
								    '/operlog/list',
							 | 
						||
| 
								 | 
							
								    response_model=PageResponseModel,
							 | 
						||
| 
								 | 
							
								    dependencies=[Depends(CheckUserInterfaceAuth('monitor:operlog:list'))],
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								async def get_system_operation_log_list(
							 | 
						||
| 
								 | 
							
								    request: Request,
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    operation_log_page_query: OperLogPageQueryModel = Depends(OperLogPageQueryModel.as_query),
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    query_db: AsyncSession = Depends(get_db),
							 | 
						||
| 
								 | 
							
								):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    # 获取分页数据
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    operation_log_page_query_result = await OperationLogService.get_operation_log_list_services(
							 | 
						||
| 
								 | 
							
								        query_db, operation_log_page_query, is_page=True
							 | 
						||
| 
								 | 
							
								    )
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    logger.info('获取成功')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.success(model_content=operation_log_page_query_result)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.delete('/operlog/clean', dependencies=[Depends(CheckUserInterfaceAuth('monitor:operlog:remove'))])
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@Log(title='操作日志', business_type=BusinessType.CLEAN)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								async def clear_system_operation_log(request: Request, query_db: AsyncSession = Depends(get_db)):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    clear_operation_log_result = await OperationLogService.clear_operation_log_services(query_db)
							 | 
						||
| 
								 | 
							
								    logger.info(clear_operation_log_result.message)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.success(msg=clear_operation_log_result.message)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.delete('/operlog/{oper_ids}', dependencies=[Depends(CheckUserInterfaceAuth('monitor:operlog:remove'))])
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@Log(title='操作日志', business_type=BusinessType.DELETE)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								async def delete_system_operation_log(request: Request, oper_ids: str, query_db: AsyncSession = Depends(get_db)):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    delete_operation_log = DeleteOperLogModel(operIds=oper_ids)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    delete_operation_log_result = await OperationLogService.delete_operation_log_services(
							 | 
						||
| 
								 | 
							
								        query_db, delete_operation_log
							 | 
						||
| 
								 | 
							
								    )
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    logger.info(delete_operation_log_result.message)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.success(msg=delete_operation_log_result.message)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.post('/operlog/export', dependencies=[Depends(CheckUserInterfaceAuth('monitor:operlog:export'))])
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@Log(title='操作日志', business_type=BusinessType.EXPORT)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								async def export_system_operation_log_list(
							 | 
						||
| 
								 | 
							
								    request: Request,
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    operation_log_page_query: OperLogPageQueryModel = Form(),
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    query_db: AsyncSession = Depends(get_db),
							 | 
						||
| 
								 | 
							
								):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    # 获取全量数据
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    operation_log_query_result = await OperationLogService.get_operation_log_list_services(
							 | 
						||
| 
								 | 
							
								        query_db, operation_log_page_query, is_page=False
							 | 
						||
| 
								 | 
							
								    )
							 | 
						||
| 
								 | 
							
								    operation_log_export_result = await OperationLogService.export_operation_log_list_services(
							 | 
						||
| 
								 | 
							
								        request, operation_log_query_result
							 | 
						||
| 
								 | 
							
								    )
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    logger.info('导出成功')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.streaming(data=bytes2file_response(operation_log_export_result))
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.get(
							 | 
						||
| 
								 | 
							
								    '/logininfor/list',
							 | 
						||
| 
								 | 
							
								    response_model=PageResponseModel,
							 | 
						||
| 
								 | 
							
								    dependencies=[Depends(CheckUserInterfaceAuth('monitor:logininfor:list'))],
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								async def get_system_login_log_list(
							 | 
						||
| 
								 | 
							
								    request: Request,
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    login_log_page_query: LoginLogPageQueryModel = Depends(LoginLogPageQueryModel.as_query),
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    query_db: AsyncSession = Depends(get_db),
							 | 
						||
| 
								 | 
							
								):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    # 获取分页数据
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    login_log_page_query_result = await LoginLogService.get_login_log_list_services(
							 | 
						||
| 
								 | 
							
								        query_db, login_log_page_query, is_page=True
							 | 
						||
| 
								 | 
							
								    )
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    logger.info('获取成功')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.success(model_content=login_log_page_query_result)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.delete('/logininfor/clean', dependencies=[Depends(CheckUserInterfaceAuth('monitor:logininfor:remove'))])
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@Log(title='登录日志', business_type=BusinessType.CLEAN)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								async def clear_system_login_log(request: Request, query_db: AsyncSession = Depends(get_db)):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    clear_login_log_result = await LoginLogService.clear_login_log_services(query_db)
							 | 
						||
| 
								 | 
							
								    logger.info(clear_login_log_result.message)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.success(msg=clear_login_log_result.message)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.delete(
							 | 
						||
| 
								 | 
							
								    '/logininfor/{info_ids}', dependencies=[Depends(CheckUserInterfaceAuth('monitor:logininfor:remove'))]
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@Log(title='登录日志', business_type=BusinessType.DELETE)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								async def delete_system_login_log(request: Request, info_ids: str, query_db: AsyncSession = Depends(get_db)):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    delete_login_log = DeleteLoginLogModel(infoIds=info_ids)
							 | 
						||
| 
								 | 
							
								    delete_login_log_result = await LoginLogService.delete_login_log_services(query_db, delete_login_log)
							 | 
						||
| 
								 | 
							
								    logger.info(delete_login_log_result.message)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.success(msg=delete_login_log_result.message)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.get(
							 | 
						||
| 
								 | 
							
								    '/logininfor/unlock/{user_name}', dependencies=[Depends(CheckUserInterfaceAuth('monitor:logininfor:unlock'))]
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@Log(title='账户解锁', business_type=BusinessType.OTHER)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								async def unlock_system_user(request: Request, user_name: str, query_db: AsyncSession = Depends(get_db)):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    unlock_user = UnlockUser(userName=user_name)
							 | 
						||
| 
								 | 
							
								    unlock_user_result = await LoginLogService.unlock_user_services(request, unlock_user)
							 | 
						||
| 
								 | 
							
								    logger.info(unlock_user_result.message)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.success(msg=unlock_user_result.message)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@logController.post('/logininfor/export', dependencies=[Depends(CheckUserInterfaceAuth('monitor:logininfor:export'))])
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								@Log(title='登录日志', business_type=BusinessType.EXPORT)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								async def export_system_login_log_list(
							 | 
						||
| 
								 | 
							
								    request: Request,
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    login_log_page_query: LoginLogPageQueryModel = Form(),
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    query_db: AsyncSession = Depends(get_db),
							 | 
						||
| 
								 | 
							
								):
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    # 获取全量数据
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    login_log_query_result = await LoginLogService.get_login_log_list_services(
							 | 
						||
| 
								 | 
							
								        query_db, login_log_page_query, is_page=False
							 | 
						||
| 
								 | 
							
								    )
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    login_log_export_result = await LoginLogService.export_login_log_list_services(login_log_query_result)
							 | 
						||
| 
								 | 
							
								    logger.info('导出成功')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ResponseUtil.streaming(data=bytes2file_response(login_log_export_result))
							 |