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
package com.highdatas.mdm.service.impl;
 
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import com.highdatas.mdm.entity.SysDispenseLogs;
import com.highdatas.mdm.mapper.SysDispenseLogsMapper;
import com.highdatas.mdm.service.ISysDispenseLogsService;
import com.highdatas.mdm.util.DbUtils;
import com.highdatas.mdm.util.pool.MqEntity;
import org.springframework.stereotype.Service;
 
import java.util.Date;
import java.util.concurrent.atomic.AtomicInteger;
 
/**
 * <p>
 *  服务实现类
 * </p>
 *
 * @author kimi
 * @since 2020-04-21
 */
@Service
public class SysDispenseLogsServiceImpl extends ServiceImpl<SysDispenseLogsMapper, SysDispenseLogs> implements ISysDispenseLogsService {
 
    @Override
    public SysDispenseLogs getLogByMqEntity(MqEntity mqEntity) {
        Wrapper<SysDispenseLogs> sysDispenseLogsWrapper = new EntityWrapper<SysDispenseLogs>()
                .eq("topic_id", mqEntity.getMsgTopicName())
                .eq("tag_id", mqEntity.getMsgTagName())
                .eq("key_id", mqEntity.getMsgKey())
                .orderBy("create_time desc");
 
 
        SysDispenseLogs sysDispenseLogs = selectOne(sysDispenseLogsWrapper);
        return sysDispenseLogs;
    }
 
    @Override
    public SysDispenseLogs getPreUnSuccessByMqEntity(MqEntity mqEntity) {
        Wrapper<SysDispenseLogs> sysDispenseLogsWrapper = new EntityWrapper<SysDispenseLogs>()
                .eq("topic_id", mqEntity.getMsgTopicName())
                .eq("tag_id", mqEntity.getMsgTagName())
                .eq("status", "fail")
                .orderBy("create_time desc");
 
 
        SysDispenseLogs sysDispenseLogs = selectOne(sysDispenseLogsWrapper);
        return sysDispenseLogs;
    }
 
    @Override
    public SysDispenseLogs createLogByMqEntity(MqEntity mqEntity) {
        SysDispenseLogs sysDispenseLogs = new SysDispenseLogs()
                .setId(DbUtils.getUUID())
                .setCreateTime(new Date())
                .setDataType(mqEntity.getType())
                .setTopicId(mqEntity.getMsgTopicName())
                .setTagId(mqEntity.getMsgTagName())
                .setKeyId(mqEntity.getMsgKey());
        int totalSize = mqEntity.getTotalSize();
        if (totalSize > 0) {
            sysDispenseLogs.setTotal(totalSize);
        }
        AtomicInteger pageNo = mqEntity.getPageNo();
        if (pageNo != null) {
            sysDispenseLogs.setPageNo(pageNo.get());
        }
 
        AtomicInteger pages = mqEntity.getPages();
        if (pages != null) {
            sysDispenseLogs.setPages(pages.get());
        }
        sysDispenseLogs.insert();
        return sysDispenseLogs;
    }
}