doum
2026-04-03 c37ea09c23b76f2da7f075292ff273a5fb579935
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
package com.doumee.service.business.impl;
 
import com.doumee.core.constants.ResponseStatus;
import com.doumee.core.exception.BusinessException;
import com.doumee.core.model.LoginUserInfo;
import com.doumee.core.model.PageData;
import com.doumee.core.model.PageWrap;
import com.doumee.core.utils.Constants;
import com.doumee.core.utils.DateUtil;
import com.doumee.core.utils.Utils;
import com.doumee.dao.business.YwGatewayMapper;
import com.doumee.dao.business.model.YwGateway;
import com.doumee.service.business.YwGatewayService;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
 
import java.util.Date;
import java.util.List;
import java.util.Objects;
 
/**
 * 网关管理Service实现
 * @author renkang
 * @date 2026/04/02
 */
@Service
public class YwGatewayServiceImpl implements YwGatewayService {
 
    @Autowired
    private YwGatewayMapper ywGatewayMapper;
 
    @Override
    public Integer create(YwGateway ywGateway) {
        if (Objects.isNull(ywGateway)
                || StringUtils.isBlank(ywGateway.getName())
                || StringUtils.isBlank(ywGateway.getGatewayCode())) {
            throw new BusinessException(ResponseStatus.BAD_REQUEST);
        }
        LoginUserInfo loginUserInfo = ywGateway.getLoginUserInfo();
        // 校验网关设备号唯一
        if (ywGatewayMapper.selectCount(new QueryWrapper<YwGateway>().lambda()
                .eq(YwGateway::getIsdeleted, Constants.ZERO)
                .eq(YwGateway::getGatewayCode, ywGateway.getGatewayCode())) > Constants.ZERO) {
            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "网关设备号重复!");
        }
        ywGateway.setCreateDate(new Date());
        ywGateway.setCreator(loginUserInfo.getId());
        ywGateway.setEditDate(new Date());
        ywGateway.setEditor(loginUserInfo.getId());
        ywGateway.setIsdeleted(Constants.ZERO);
        ywGatewayMapper.insert(ywGateway);
        return ywGateway.getId();
    }
 
    @Override
    public void deleteById(Integer id, LoginUserInfo user) {
        ywGatewayMapper.update(new UpdateWrapper<YwGateway>()
                .lambda()
                .set(YwGateway::getIsdeleted, Constants.ONE)
                .set(YwGateway::getEditDate, DateUtil.getCurrDateTime())
                .set(YwGateway::getEditor, user.getId())
                .eq(YwGateway::getId, id)
        );
    }
 
    @Override
    public void deleteByIdInBatch(List<Integer> ids, LoginUserInfo user) {
        if (CollectionUtils.isEmpty(ids)) {
            return;
        }
        for (Integer id : ids) {
            this.deleteById(id, user);
        }
    }
 
    @Override
    public void updateById(YwGateway ywGateway) {
        if (Objects.isNull(ywGateway)
                || Objects.isNull(ywGateway.getId())
                || StringUtils.isBlank(ywGateway.getName())
                || StringUtils.isBlank(ywGateway.getGatewayCode())) {
            throw new BusinessException(ResponseStatus.BAD_REQUEST);
        }
        LoginUserInfo loginUserInfo = ywGateway.getLoginUserInfo();
        // 校验网关设备号唯一(排除自身)
        if (ywGatewayMapper.selectCount(new QueryWrapper<YwGateway>().lambda()
                .eq(YwGateway::getIsdeleted, Constants.ZERO)
                .eq(YwGateway::getGatewayCode, ywGateway.getGatewayCode())
                .ne(YwGateway::getId, ywGateway.getId())) > Constants.ZERO) {
            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "网关设备号重复!");
        }
        ywGateway.setEditDate(new Date());
        ywGateway.setEditor(loginUserInfo.getId());
        ywGatewayMapper.updateById(ywGateway);
    }
 
    @Override
    public void updateStatusById(YwGateway ywGateway) {
        YwGateway model = new YwGateway();
        model.setId(ywGateway.getId());
        model.setStatus(ywGateway.getStatus());
        ywGatewayMapper.updateById(model);
    }
 
    @Override
    public YwGateway findById(Integer id) {
        return ywGatewayMapper.selectJoinOne(YwGateway.class,
                new MPJLambdaWrapper<YwGateway>()
                        .selectAll(YwGateway.class)
                        .selectAs(com.doumee.dao.business.model.YwProject::getName, YwGateway::getProjectName)
                        .leftJoin(com.doumee.dao.business.model.YwProject.class, com.doumee.dao.business.model.YwProject::getId, YwGateway::getProjectId)
                        .eq(YwGateway::getId, id)
                        .last(" limit 1 ")
        );
    }
 
    @Override
    public PageData<YwGateway> findPage(PageWrap<YwGateway> pageWrap) {
        IPage<YwGateway> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
        MPJLambdaWrapper<YwGateway> queryWrapper = new MPJLambdaWrapper<>();
        Utils.MP.blankToNull(pageWrap.getModel());
        YwGateway model = pageWrap.getModel();
        queryWrapper.selectAll(YwGateway.class)
                .selectAs(com.doumee.dao.business.model.YwProject::getName, YwGateway::getProjectName)
                .leftJoin(com.doumee.dao.business.model.YwProject.class, com.doumee.dao.business.model.YwProject::getId, YwGateway::getProjectId)
                .and(Objects.nonNull(model) && StringUtils.isNotBlank(model.getName()),
                        i -> i.like(YwGateway::getName, model.getName()).or().like(YwGateway::getGatewayCode, model.getName()))
                .eq(Objects.nonNull(model) && Objects.nonNull(model.getStatus()), YwGateway::getStatus, model.getStatus())
                .eq(Objects.nonNull(model) && Objects.nonNull(model.getProjectId()), YwGateway::getProjectId, model.getProjectId())
                .eq(YwGateway::getIsdeleted, Constants.ZERO)
                .orderByDesc(YwGateway::getCreateDate);
        IPage<YwGateway> iPage = ywGatewayMapper.selectJoinPage(page, YwGateway.class, queryWrapper);
        return PageData.from(iPage);
    }
}