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.

115 lines
6.7 KiB

1 month ago
from fastapi import APIRouter, Request
from fastapi import Depends
from config.get_db import get_db
from module_admin.service.login_service import get_current_user, CurrentUserInfoServiceResponse
from module_admin.service.dscatalog_service import *
from module_admin.entity.vo.dscatalog_vo import *
from module_admin.dao.dscatalog_dao import *
from utils.response_util import *
from utils.log_util import *
from module_admin.aspect.interface_auth import CheckUserInterfaceAuth
from module_admin.aspect.data_scope import GetDataScope
from module_admin.annotation.log_annotation import log_decorator
dscatalogController = APIRouter(dependencies=[Depends(get_current_user)])
@dscatalogController.post("/dscatalog/tree", response_model=DscatalogTree, dependencies=[Depends(CheckUserInterfaceAuth('common'))])
async def get_system_dscatalog_tree(request: Request, dscatalog_query: DscatalogModel, query_db: Session = Depends(get_db), data_scope_sql: str = Depends(GetDataScope('SysDscatalog'))):
try:
dscatalog_query_result = DscatalogService.get_dscatalog_tree_services(query_db, dscatalog_query, data_scope_sql)
logger.info('获取成功')
return response_200(data=dscatalog_query_result, message="获取成功")
except Exception as e:
logger.exception(e)
return response_500(data="", message=str(e))
@dscatalogController.post("/dscatalog/forEditOption", response_model=DscatalogTree, dependencies=[Depends(CheckUserInterfaceAuth('common'))])
async def get_system_dscatalog_tree_for_edit_option(request: Request, dscatalog_query: DscatalogModel, query_db: Session = Depends(get_db), data_scope_sql: str = Depends(GetDataScope('SysDscatalog'))):
try:
dscatalog_query_result = DscatalogService.get_dscatalog_tree_for_edit_option_services(query_db, dscatalog_query, data_scope_sql)
logger.info('获取成功')
return response_200(data=dscatalog_query_result, message="获取成功")
except Exception as e:
logger.exception(e)
return response_500(data="", message=str(e))
@dscatalogController.post("/dscatalog/get", response_model=DscatalogResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:dscatalog:list'))])
async def get_system_dscatalog_list(request: Request, dscatalog_query: DscatalogModel, query_db: Session = Depends(get_db), data_scope_sql: str = Depends(GetDataScope('SysDscatalog'))):
try:
dscatalog_query_result = DscatalogService.get_dscatalog_list_services(query_db, dscatalog_query, data_scope_sql)
logger.info('获取成功')
return response_200(data=dscatalog_query_result, message="获取成功")
except Exception as e:
logger.exception(e)
return response_500(data="", message=str(e))
@dscatalogController.post("/dscatalog/add", response_model=CrudDscatalogResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:dscatalog:add'))])
@log_decorator(title='数据资产管理', business_type=1)
async def add_system_dscatalog(request: Request, add_dscatalog: DscatalogModel, query_db: Session = Depends(get_db), current_user: CurrentUserInfoServiceResponse = Depends(get_current_user)):
try:
add_dscatalog.create_by = current_user.user.user_name
add_dscatalog.update_by = current_user.user.user_name
add_dscatalog_result = DscatalogService.add_dscatalog_services(query_db, add_dscatalog)
if add_dscatalog_result.is_success:
logger.info(add_dscatalog_result.message)
return response_200(data=add_dscatalog_result, message=add_dscatalog_result.message)
else:
logger.warning(add_dscatalog_result.message)
return response_400(data="", message=add_dscatalog_result.message)
except Exception as e:
logger.exception(e)
return response_500(data="", message=str(e))
@dscatalogController.patch("/dscatalog/edit", response_model=CrudDscatalogResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:dscatalog:edit'))])
@log_decorator(title='数据资产管理', business_type=2)
async def edit_system_dscatalog(request: Request, edit_dscatalog: DscatalogModel, query_db: Session = Depends(get_db), current_user: CurrentUserInfoServiceResponse = Depends(get_current_user)):
try:
edit_dscatalog.update_by = current_user.user.user_name
edit_dscatalog.update_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
edit_dscatalog_result = DscatalogService.edit_dscatalog_services(query_db, edit_dscatalog)
#print(88888888888888,edit_dscatalog,888888888888888)
if edit_dscatalog_result.is_success:
logger.info(edit_dscatalog_result.message)
return response_200(data=edit_dscatalog_result, message=edit_dscatalog_result.message)
else:
logger.warning(edit_dscatalog_result.message)
return response_400(data="", message=edit_dscatalog_result.message)
except Exception as e:
logger.exception(e)
return response_500(data="", message=str(e))
@dscatalogController.post("/dscatalog/delete", response_model=CrudDscatalogResponse, dependencies=[Depends(CheckUserInterfaceAuth('system:dscatalog:remove'))])
@log_decorator(title='数据资产管理', business_type=3)
async def delete_system_dscatalog(request: Request, delete_dscatalog: DeleteDscatalogModel, query_db: Session = Depends(get_db), current_user: CurrentUserInfoServiceResponse = Depends(get_current_user)):
try:
delete_dscatalog.update_by = current_user.user.user_name
delete_dscatalog.update_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
delete_dscatalog_result = DscatalogService.delete_dscatalog_services(query_db, delete_dscatalog)
if delete_dscatalog_result.is_success:
logger.info(delete_dscatalog_result.message)
return response_200(data=delete_dscatalog_result, message=delete_dscatalog_result.message)
else:
logger.warning(delete_dscatalog_result.message)
return response_400(data="", message=delete_dscatalog_result.message)
except Exception as e:
logger.exception(e)
return response_500(data="", message=str(e))
@dscatalogController.get("/dscatalog/{dscatalog_id}", response_model=DscatalogModel, dependencies=[Depends(CheckUserInterfaceAuth('system:dscatalog:query'))])
async def query_detail_system_dscatalog(request: Request, dscatalog_id: int, query_db: Session = Depends(get_db)):
try:
detail_dscatalog_result = DscatalogService.detail_dscatalog_services(query_db, dscatalog_id)
logger.info(f'获取dscatalog_id为{dscatalog_id}的信息成功')
return response_200(data=detail_dscatalog_result, message='获取成功')
except Exception as e:
logger.exception(e)
return response_500(data="", message=str(e))