jinpengyong
2023-09-05 8ec7046779aa7ae510cbb584fbaa87cc45cfc49b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
package com.moral.api.service.impl;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.moral.api.config.mybatis.wrapper.NullFilterWrapper;
import com.moral.api.entity.ManageLog;
import com.moral.api.entity.SysDictData;
import com.moral.api.mapper.ManageLogMapper;
import com.moral.api.mapper.SysDictDataMapper;
import com.moral.api.mapper.SysDictTypeMapper;
import com.moral.api.pojo.dto.manageLog.ManageLogQueryDTO;
import com.moral.api.pojo.form.manageLog.ManageLogQueryForm;
import com.moral.api.service.ManageLogService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.moral.constant.Constants;
import com.moral.constant.ResponseCodeEnum;
import com.moral.util.ConvertUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.ObjectUtils;
 
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
/**
 * <p>
 * 后台操作日志表 服务实现类
 * </p>
 *
 * @author moral
 * @since 2021-04-12
 */
@Service
public class ManageLogServiceImpl extends ServiceImpl<ManageLogMapper, ManageLog> implements ManageLogService {
 
    @Autowired
    ManageLogMapper manageLogMapper;
    @Autowired
    SysDictTypeMapper sysDictTypeMapper;
    @Autowired
    SysDictDataMapper sysDictDataMapper;
 
    @Override
    public ManageLogQueryDTO queryManageLog(ManageLogQueryForm form) {
        ManageLogQueryDTO dto = new ManageLogQueryDTO();
        Integer pageCount = form.getPage();
        Integer size = form.getSize();
        String order = form.getOrder();
        String orderType = form.getOrderType();
        String account = form.getAccount();
        String userName = form.getUserName();
        String ip = form.getIp();
        List<String> types = form.getType();
        Date startTime = form.getStartTime();
        Date endTime = form.getEndTime();
 
        //构造查询条件
        Page<ManageLog> page = new Page<>(pageCount, size);
        NullFilterWrapper<ManageLog> queryWrapper = new NullFilterWrapper<>();
 
        queryWrapper.like("account",account);
        queryWrapper.like("user_name",userName);
        queryWrapper.eq("ip",ip);
        queryWrapper.in("type",types);
        queryWrapper.between("create_time",startTime,endTime);
        if (!ObjectUtils.isEmpty(order)) {//排序条件
            if (!ObjectUtils.isEmpty(orderType)) {
                if (orderType.equals(Constants.ORDER_ASC))
                    queryWrapper.orderByAsc(ConvertUtils.toLine(order));
                else
                    queryWrapper.orderByDesc(ConvertUtils.toLine(order));
            }
        }
 
        //查询结果
        Page<ManageLog> resultPage = manageLogMapper.selectPage(page, queryWrapper);
        List<ManageLog> manageLogs = resultPage.getRecords();
 
        //根据字典表将Type转化为汉字
        QueryWrapper<SysDictData> dataWrapper = new QueryWrapper<>();
        dataWrapper.eq("dict_type_id",2);
        List<SysDictData> sysDictData = sysDictDataMapper.selectList(dataWrapper);
        Map<String,String> map = new HashMap<>();
        for (SysDictData data : sysDictData) {
            map.put(data.getDataKey(),data.getDataValue());
        }
 
        for (ManageLog manageLog : manageLogs) {
            String type = manageLog.getType();
            String typeValue = map.get(type);
            manageLog.setType(typeValue);
        }
 
        dto.setCode(ResponseCodeEnum.SUCCESS.getCode());
        dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg());
        dto.setCurrent(page.getCurrent());
        dto.setPage(page.getPages());
        dto.setSize(page.getSize());
        dto.setTotal(page.getTotal());
        dto.setManageLogs(manageLogs);
        return dto;
    }
}