|
| 1 | +from fastapi import APIRouter, Request |
| 2 | +from fastapi import Depends |
| 3 | +from config.get_db import get_db |
| 4 | +from module_admin.service.login_service import get_current_user, CurrentUserInfoServiceResponse |
| 5 | +from module_admin.service.config_service import * |
| 6 | +from module_admin.entity.vo.config_vo import * |
| 7 | +from utils.response_util import * |
| 8 | +from utils.log_util import * |
| 9 | +from utils.page_util import get_page_obj |
| 10 | +from utils.common_util import bytes2file_response |
| 11 | +from module_admin.aspect.interface_auth import CheckUserInterfaceAuth |
| 12 | +from module_admin.annotation.log_annotation import log_decorator |
| 13 | + |
| 14 | + |
| 15 | +configController = APIRouter(dependencies=[Depends(get_current_user)]) |
| 16 | + |
| 17 | + |
| 18 | +@configController.post("/config/get", response_model=ConfigPageObjectResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:config:list'))]) |
| 19 | +async def get_system_config_list(request: Request, config_page_query: ConfigPageObject, query_db: Session = Depends(get_db)): |
| 20 | + try: |
| 21 | + config_query = ConfigQueryModel(**config_page_query.dict()) |
| 22 | + # 获取全量数据 |
| 23 | + config_query_result = ConfigService.get_config_list_services(query_db, config_query) |
| 24 | + # 分页操作 |
| 25 | + config_page_query_result = get_page_obj(config_query_result, config_page_query.page_num, config_page_query.page_size) |
| 26 | + logger.info('获取成功') |
| 27 | + return response_200(data=config_page_query_result, message="获取成功") |
| 28 | + except Exception as e: |
| 29 | + logger.exception(e) |
| 30 | + return response_500(data="", message=str(e)) |
| 31 | + |
| 32 | + |
| 33 | +@configController.post("/config/add", response_model=CrudConfigResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:config:add'))]) |
| 34 | +@log_decorator(title='参数管理', business_type=1) |
| 35 | +async def add_system_config(request: Request, add_config: ConfigModel, query_db: Session = Depends(get_db), current_user: CurrentUserInfoServiceResponse = Depends(get_current_user)): |
| 36 | + try: |
| 37 | + add_config.create_by = current_user.user.user_name |
| 38 | + add_config.update_by = current_user.user.user_name |
| 39 | + add_config_result = await ConfigService.add_config_services(request, query_db, add_config) |
| 40 | + if add_config_result.is_success: |
| 41 | + logger.info(add_config_result.message) |
| 42 | + return response_200(data=add_config_result, message=add_config_result.message) |
| 43 | + else: |
| 44 | + logger.warning(add_config_result.message) |
| 45 | + return response_400(data="", message=add_config_result.message) |
| 46 | + except Exception as e: |
| 47 | + logger.exception(e) |
| 48 | + return response_500(data="", message=str(e)) |
| 49 | + |
| 50 | + |
| 51 | +@configController.patch("/config/edit", response_model=CrudConfigResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:config:edit'))]) |
| 52 | +@log_decorator(title='参数管理', business_type=2) |
| 53 | +async def edit_system_config(request: Request, edit_config: ConfigModel, query_db: Session = Depends(get_db), current_user: CurrentUserInfoServiceResponse = Depends(get_current_user)): |
| 54 | + try: |
| 55 | + edit_config.update_by = current_user.user.user_name |
| 56 | + edit_config.update_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S") |
| 57 | + edit_config_result = await ConfigService.edit_config_services(request, query_db, edit_config) |
| 58 | + if edit_config_result.is_success: |
| 59 | + logger.info(edit_config_result.message) |
| 60 | + return response_200(data=edit_config_result, message=edit_config_result.message) |
| 61 | + else: |
| 62 | + logger.warning(edit_config_result.message) |
| 63 | + return response_400(data="", message=edit_config_result.message) |
| 64 | + except Exception as e: |
| 65 | + logger.exception(e) |
| 66 | + return response_500(data="", message=str(e)) |
| 67 | + |
| 68 | + |
| 69 | +@configController.post("/config/delete", response_model=CrudConfigResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:config:remove'))]) |
| 70 | +@log_decorator(title='参数管理', business_type=3) |
| 71 | +async def delete_system_config(request: Request, delete_config: DeleteConfigModel, query_db: Session = Depends(get_db)): |
| 72 | + try: |
| 73 | + delete_config_result = await ConfigService.delete_config_services(request, query_db, delete_config) |
| 74 | + if delete_config_result.is_success: |
| 75 | + logger.info(delete_config_result.message) |
| 76 | + return response_200(data=delete_config_result, message=delete_config_result.message) |
| 77 | + else: |
| 78 | + logger.warning(delete_config_result.message) |
| 79 | + return response_400(data="", message=delete_config_result.message) |
| 80 | + except Exception as e: |
| 81 | + logger.exception(e) |
| 82 | + return response_500(data="", message=str(e)) |
| 83 | + |
| 84 | + |
| 85 | +@configController.get("/config/{config_id}", response_model=ConfigModel, dependencies=[Depends(CheckUserInterfaceAuth('system:config:query'))]) |
| 86 | +async def query_detail_system_config(request: Request, config_id: int, query_db: Session = Depends(get_db)): |
| 87 | + try: |
| 88 | + detail_config_result = ConfigService.detail_config_services(query_db, config_id) |
| 89 | + logger.info(f'获取config_id为{config_id}的信息成功') |
| 90 | + return response_200(data=detail_config_result, message='获取成功') |
| 91 | + except Exception as e: |
| 92 | + logger.exception(e) |
| 93 | + return response_500(data="", message=str(e)) |
| 94 | + |
| 95 | + |
| 96 | +@configController.post("/config/export", dependencies=[Depends(CheckUserInterfaceAuth('system:config:export'))]) |
| 97 | +@log_decorator(title='参数管理', business_type=5) |
| 98 | +async def export_system_config_list(request: Request, config_query: ConfigQueryModel, query_db: Session = Depends(get_db)): |
| 99 | + try: |
| 100 | + # 获取全量数据 |
| 101 | + config_query_result = ConfigService.get_config_list_services(query_db, config_query) |
| 102 | + config_export_result = ConfigService.export_config_list_services(config_query_result) |
| 103 | + logger.info('导出成功') |
| 104 | + return streaming_response_200(data=bytes2file_response(config_export_result)) |
| 105 | + except Exception as e: |
| 106 | + logger.exception(e) |
| 107 | + return response_500(data="", message=str(e)) |
| 108 | + |
| 109 | + |
| 110 | +@configController.post("/config/refresh", response_model=CrudConfigResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:config:edit'))]) |
| 111 | +@log_decorator(title='参数管理', business_type=2) |
| 112 | +async def refresh_system_config(request: Request, query_db: Session = Depends(get_db)): |
| 113 | + try: |
| 114 | + refresh_config_result = await ConfigService.refresh_sys_config_services(request, query_db) |
| 115 | + if refresh_config_result.is_success: |
| 116 | + logger.info(refresh_config_result.message) |
| 117 | + return response_200(data=refresh_config_result, message=refresh_config_result.message) |
| 118 | + else: |
| 119 | + logger.warning(refresh_config_result.message) |
| 120 | + return response_400(data="", message=refresh_config_result.message) |
| 121 | + except Exception as e: |
| 122 | + logger.exception(e) |
| 123 | + return response_500(data="", message=str(e)) |
0 commit comments