perf: 优化在线用户模块service层及异常处理
This commit is contained in:
@@ -16,28 +16,18 @@ onlineController = APIRouter(prefix='/monitor/online', dependencies=[Depends(Log
|
|||||||
|
|
||||||
@onlineController.get("/list", response_model=PageResponseModel, dependencies=[Depends(CheckUserInterfaceAuth('monitor:online:list'))])
|
@onlineController.get("/list", response_model=PageResponseModel, dependencies=[Depends(CheckUserInterfaceAuth('monitor:online:list'))])
|
||||||
async def get_monitor_online_list(request: Request, online_page_query: OnlineQueryModel = Depends(OnlineQueryModel.as_query)):
|
async def get_monitor_online_list(request: Request, online_page_query: OnlineQueryModel = Depends(OnlineQueryModel.as_query)):
|
||||||
try:
|
# 获取全量数据
|
||||||
# 获取全量数据
|
online_query_result = await OnlineService.get_online_list_services(request, online_page_query)
|
||||||
online_query_result = await OnlineService.get_online_list_services(request, online_page_query)
|
logger.info('获取成功')
|
||||||
logger.info('获取成功')
|
|
||||||
return ResponseUtil.success(model_content=PageResponseModel(rows=online_query_result, total=len(online_query_result)))
|
return ResponseUtil.success(model_content=PageResponseModel(rows=online_query_result, total=len(online_query_result)))
|
||||||
except Exception as e:
|
|
||||||
logger.exception(e)
|
|
||||||
return ResponseUtil.error(msg=str(e))
|
|
||||||
|
|
||||||
|
|
||||||
@onlineController.delete("/{token_ids}", dependencies=[Depends(CheckUserInterfaceAuth('monitor:online:forceLogout'))])
|
@onlineController.delete("/{token_ids}", dependencies=[Depends(CheckUserInterfaceAuth('monitor:online:forceLogout'))])
|
||||||
@log_decorator(title='在线用户', business_type=BusinessType.FORCE)
|
@log_decorator(title='在线用户', business_type=BusinessType.FORCE)
|
||||||
async def delete_monitor_online(request: Request, token_ids: str, query_db: AsyncSession = Depends(get_db)):
|
async def delete_monitor_online(request: Request, token_ids: str, query_db: AsyncSession = Depends(get_db)):
|
||||||
try:
|
delete_online = DeleteOnlineModel(tokenIds=token_ids)
|
||||||
delete_online = DeleteOnlineModel(tokenIds=token_ids)
|
delete_online_result = await OnlineService.delete_online_services(request, delete_online)
|
||||||
delete_online_result = await OnlineService.delete_online_services(request, delete_online)
|
logger.info(delete_online_result.message)
|
||||||
if delete_online_result.is_success:
|
|
||||||
logger.info(delete_online_result.message)
|
return ResponseUtil.success(msg=delete_online_result.message)
|
||||||
return ResponseUtil.success(msg=delete_online_result.message)
|
|
||||||
else:
|
|
||||||
logger.warning(delete_online_result.message)
|
|
||||||
return ResponseUtil.failure(msg=delete_online_result.message)
|
|
||||||
except Exception as e:
|
|
||||||
logger.exception(e)
|
|
||||||
return ResponseUtil.error(msg=str(e))
|
|
||||||
|
@@ -3,6 +3,7 @@ from jose import jwt
|
|||||||
from config.env import JwtConfig, RedisInitKeyConfig
|
from config.env import JwtConfig, RedisInitKeyConfig
|
||||||
from module_admin.entity.vo.online_vo import *
|
from module_admin.entity.vo.online_vo import *
|
||||||
from module_admin.entity.vo.common_vo import CrudResponseModel
|
from module_admin.entity.vo.common_vo import CrudResponseModel
|
||||||
|
from exceptions.exception import ServiceException
|
||||||
from utils.common_util import CamelCaseUtil
|
from utils.common_util import CamelCaseUtil
|
||||||
|
|
||||||
|
|
||||||
@@ -65,7 +66,6 @@ class OnlineService:
|
|||||||
token_id_list = page_object.token_ids.split(',')
|
token_id_list = page_object.token_ids.split(',')
|
||||||
for token_id in token_id_list:
|
for token_id in token_id_list:
|
||||||
await request.app.state.redis.delete(f"{RedisInitKeyConfig.ACCESS_TOKEN.get('key')}:{token_id}")
|
await request.app.state.redis.delete(f"{RedisInitKeyConfig.ACCESS_TOKEN.get('key')}:{token_id}")
|
||||||
result = dict(is_success=True, message='强退成功')
|
return CrudResponseModel(is_success=True, message='强退成功')
|
||||||
else:
|
else:
|
||||||
result = dict(is_success=False, message='传入session_id为空')
|
raise ServiceException(message='传入session_id为空')
|
||||||
return CrudResponseModel(**result)
|
|
||||||
|
Reference in New Issue
Block a user