111
k94314517
2023-09-13 f06d894f2f15798d24a13d15360ac9fa5e8461d1
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
package doumeemes.service.system.impl;
 
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import doumeemes.core.model.LoginUserInfo;
import doumeemes.core.model.PageData;
import doumeemes.core.model.PageWrap;
import doumeemes.core.utils.Constants;
import doumeemes.dao.system.SystemRoleMapper;
import doumeemes.dao.system.dto.QuerySystemRoleDTO;
import doumeemes.dao.system.model.SystemRole;
import doumeemes.dao.system.vo.SystemRoleListVO;
import doumeemes.service.system.SystemMenuService;
import doumeemes.service.system.SystemPermissionService;
import doumeemes.service.system.SystemRoleService;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import org.apache.shiro.SecurityUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils;
 
import java.util.List;
 
/**
 * 系统角色Service实现
 * @author Eva.Caesar Liu
 * @date 2022/04/18 18:12
 */
@Service
public class SystemRoleServiceImpl implements SystemRoleService {
 
    @Autowired
    private SystemRoleMapper systemRoleMapper;
 
    @Autowired
    private SystemMenuService systemMenuService;
 
    @Autowired
    private SystemPermissionService systemPermissionService;
 
    @Override
    public Integer create(SystemRole systemRole) {
        systemRoleMapper.insert(systemRole);
        return systemRole.getId();
    }
 
    @Override
    public void deleteById(Integer id) {
        SystemRole systemRole = new SystemRole();
        systemRole.setId(id);
        systemRole.setDeleted(Boolean.TRUE);
        this.updateById(systemRole);
    }
 
    @Override
    @Transactional
    public void deleteByIdInBatch(List<Integer> ids) {
        if (CollectionUtils.isEmpty(ids)) return;
        for (Integer id : ids) {
            this.deleteById(id);
        }
    }
 
    @Override
    public void updateById(SystemRole systemRole) {
        systemRoleMapper.updateById(systemRole);
    }
 
    @Override
    @Transactional
    public void updateByIdInBatch(List<SystemRole> systemRoles) {
        if (CollectionUtils.isEmpty(systemRoles)) return;
        for (SystemRole systemRole: systemRoles) {
            this.updateById(systemRole);
        }
    }
 
    @Override
    public SystemRole findById(Integer id) {
        return systemRoleMapper.selectById(id);
    }
 
    @Override
    public List<SystemRole> findByUserId(Integer userId) {
        return systemRoleMapper.selectByUserId(userId);
    }
    @Override
    public List<SystemRole> findByUserModel(Integer userId,SystemRole role){
        return systemRoleMapper.selectByUserModel(userId,role);
    }
 
    @Override
    public SystemRole findOne(SystemRole systemRole) {
        QueryWrapper<SystemRole> wrapper = new QueryWrapper<>(systemRole);
        return systemRoleMapper.selectOne(wrapper.last("limit 1"));
    }
 
    @Override
    public List<SystemRole> findList(SystemRole systemRole) {
        LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
        systemRole.setDeleted(Boolean.FALSE);
        systemRole.setType(Constants.ROLETYPE.plat);
        if(Constants.equalsInteger(user.getType(),Constants.USERTYPE.COM)){
            systemRole.setType(Constants.ROLETYPE.com);
            systemRole.setCompanyId(user.getCompany().getId());
        }
        Wrapper<SystemRole> wrapper = new QueryWrapper<>(systemRole);
        return systemRoleMapper.selectList(wrapper);
    }
  
    @Override
    public PageData<SystemRoleListVO> findPage(PageWrap<QuerySystemRoleDTO> pageWrap) {
        LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
        if(pageWrap.getModel().getType()==null) {
            pageWrap.getModel().setType(Constants.ROLETYPE.plat);
        }
        if(Constants.equalsInteger(user.getType(),Constants.USERTYPE.COM)){
            pageWrap.getModel().setType(Constants.ROLETYPE.com);
            pageWrap.getModel().setCompanyId(user.getCompany().getId());
        }
        PageHelper.startPage(pageWrap.getPage(), pageWrap.getCapacity());
        List<SystemRoleListVO> roleList = systemRoleMapper.selectManageList(pageWrap.getModel(), pageWrap.getOrderByClause());
        for (SystemRoleListVO role : roleList) {
            role.setMenus(systemMenuService.findByRoleId(role.getId()));
            role.setPermissions(systemPermissionService.findByRoleId(role.getId()));
        }
        return PageData.from(new PageInfo<>(roleList));
    }
 
    @Override
    public long count(SystemRole systemRole) {
        Wrapper<SystemRole> wrapper = new QueryWrapper<>(systemRole);
        return systemRoleMapper.selectCount(wrapper);
    }
}