127 lines
4.2 KiB
Python
127 lines
4.2 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from app.core.exceptions import CustomException
|
|
from app.utils.excel_util import ExcelUtil
|
|
|
|
from ..auth.schema import AuthSchema
|
|
from .crud import OperationLogCRUD
|
|
from .schema import (
|
|
OperationLogCreateSchema,
|
|
OperationLogOutSchema,
|
|
OperationLogQueryParam
|
|
)
|
|
|
|
|
|
class OperationLogService:
|
|
"""
|
|
日志模块服务层
|
|
"""
|
|
|
|
@classmethod
|
|
async def get_log_detail_service(cls, auth: AuthSchema, id: int) -> dict:
|
|
"""
|
|
获取日志详情
|
|
|
|
参数:
|
|
- auth (AuthSchema): 认证信息模型
|
|
- id (int): 日志 ID
|
|
|
|
返回:
|
|
- dict: 日志详情字典
|
|
"""
|
|
log = await OperationLogCRUD(auth).get_by_id_crud(id=id)
|
|
log_dict = OperationLogOutSchema.model_validate(log).model_dump()
|
|
return log_dict
|
|
|
|
@classmethod
|
|
async def get_log_list_service(cls, auth: AuthSchema, search: OperationLogQueryParam | None = None, order_by: list | None = None) -> list[dict]:
|
|
"""
|
|
获取日志列表
|
|
|
|
参数:
|
|
- auth (AuthSchema): 认证信息模型
|
|
- search (OperationLogQueryParam | None): 日志查询参数模型
|
|
- order_by (list | None): 排序字段列表
|
|
|
|
返回:
|
|
- list[dict]: 日志详情字典列表
|
|
"""
|
|
|
|
log_list = await OperationLogCRUD(auth).get_list_crud(search=search.__dict__, order_by=order_by)
|
|
log_dict_list = [OperationLogOutSchema.model_validate(log).model_dump() for log in log_list]
|
|
return log_dict_list
|
|
|
|
@classmethod
|
|
async def create_log_service(cls, auth: AuthSchema, data: OperationLogCreateSchema) -> dict:
|
|
"""
|
|
创建日志
|
|
|
|
参数:
|
|
- auth (AuthSchema): 认证信息模型
|
|
- data (OperationLogCreateSchema): 日志创建模型
|
|
|
|
返回:
|
|
- dict: 日志详情字典
|
|
"""
|
|
new_log = await OperationLogCRUD(auth).create(data=data)
|
|
new_log_dict = OperationLogOutSchema.model_validate(new_log).model_dump()
|
|
return new_log_dict
|
|
|
|
@classmethod
|
|
async def delete_log_service(cls, auth: AuthSchema, ids: list[int]) -> None:
|
|
"""
|
|
删除日志
|
|
|
|
参数:
|
|
- auth (AuthSchema): 认证信息模型
|
|
- ids (list[int]): 日志 ID 列表
|
|
|
|
返回:
|
|
- None
|
|
"""
|
|
if len(ids) < 1:
|
|
raise CustomException(msg='删除失败,删除对象不能为空')
|
|
await OperationLogCRUD(auth).delete(ids=ids)
|
|
|
|
@classmethod
|
|
async def export_log_list_service(cls, operation_log_list: list[dict]) -> bytes:
|
|
"""
|
|
导出日志信息
|
|
|
|
参数:
|
|
- operation_log_list (list[dict]): 操作日志信息列表
|
|
|
|
返回:
|
|
- bytes: 操作日志信息excel的二进制数据
|
|
"""
|
|
# 操作日志字段映射
|
|
mapping_dict = {
|
|
'id': '编号',
|
|
'type': '日志类型',
|
|
'request_path': '请求URL',
|
|
'request_method': '请求方式',
|
|
'request_payload': '请求参数',
|
|
'request_ip': '操作地址',
|
|
'login_location': '登录位置',
|
|
'request_os': '操作系统',
|
|
'request_browser': '浏览器',
|
|
'response_json': '返回参数',
|
|
'response_code': '相应状态',
|
|
'process_time': '处理时间',
|
|
'description': '备注',
|
|
'created_time': '创建时间',
|
|
'updated_time': '更新时间',
|
|
'created_id': '创建者ID',
|
|
'updated_id': '更新者ID',
|
|
}
|
|
|
|
# 处理数据
|
|
data = operation_log_list.copy()
|
|
for item in data:
|
|
# 处理状态
|
|
item['response_code'] = '成功' if item.get('response_code') == 200 else '失败'
|
|
# 处理日志类型 - 修正与schema.py保持一致
|
|
item['type'] = '登录日志' if item.get('type') == 1 else '操作日志'
|
|
item['creator'] = item.get('creator', {}).get('name', '未知') if isinstance(item.get('creator'), dict) else '未知'
|
|
|
|
return ExcelUtil.export_list2excel(list_data=data, mapping_dict=mapping_dict) |