package com.whyc.service;
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.whyc.mapper.CommonMapper;
|
import com.whyc.mapper.PermitGroupMapper;
|
import com.whyc.mapper.PermitGroupUserMapper;
|
import com.whyc.mapper.UserInfMapper;
|
import com.whyc.pojo.PermitGroup;
|
import com.whyc.pojo.PermitGroupUser;
|
import com.whyc.pojo.UserInf;
|
import org.springframework.stereotype.Service;
|
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.web.bind.annotation.RequestParam;
|
|
import javax.annotation.Resource;
|
import java.sql.Wrapper;
|
import java.util.HashMap;
|
import java.util.List;
|
import java.util.Map;
|
import java.util.stream.Collectors;
|
|
@Service
|
@Transactional
|
public class PermitGroupService {
|
|
@Resource
|
private PermitGroupMapper mapper;
|
|
@Resource
|
private PermitGroupUserMapper permitGroupUserMapper;
|
|
@Resource
|
private CommonMapper commonMapper;
|
|
@Resource
|
private UserInfMapper userInfMapper;
|
|
public void add(List<PermitGroup> permitGroupList) {
|
//权限组id生成
|
int maxValue = (int) commonMapper.getMaxValue("db_user", "tb_user_permitgroup", "permit_group_id");
|
int newPermitGroupId = maxValue+1;
|
permitGroupList.stream().forEach(permitGroup -> permitGroup.setPermitGroupId(newPermitGroupId));
|
mapper.insertBatchSomeColumn(permitGroupList);
|
}
|
|
|
public void update(List<PermitGroup> permitGroupList) {
|
//先删除,后增加
|
UpdateWrapper<PermitGroup> wrapper = Wrappers.update();
|
wrapper.eq("permit_group_id",permitGroupList.get(0).getPermitGroupId());
|
mapper.delete(wrapper);
|
|
mapper.insertBatchSomeColumn(permitGroupList);
|
}
|
|
|
public void delete(Integer permitGroupId) {
|
//删除权限组表记录
|
UpdateWrapper<PermitGroup> groupWrapper = Wrappers.update();
|
groupWrapper.eq("permit_group_id",permitGroupId);
|
mapper.delete(groupWrapper);
|
//删除权限组对应的用户记录
|
UpdateWrapper<PermitGroupUser> groupUserWrapper = Wrappers.update();
|
groupUserWrapper.eq("permit_group_id",permitGroupId);
|
permitGroupUserMapper.delete(groupUserWrapper);
|
|
}
|
|
public List<PermitGroup> getList() {
|
QueryWrapper<PermitGroup> wrapper = Wrappers.query();
|
wrapper.select("distinct permit_group_id,permit_group_name");
|
return mapper.selectList(wrapper);
|
}
|
|
public Map getPermitGroupInfo(Integer permitGroupId) {
|
Map<String,List> resultMap = new HashMap<>();
|
//查询权限组已添加的用户
|
List<UserInf> relatedUserInfList = permitGroupUserMapper.getUserInf(permitGroupId);
|
//查询权限组未添加的用户
|
List<UserInf> allUserInfList = userInfMapper.selectList(null);
|
List<UserInf> notRelatedUserInfList = allUserInfList.stream().filter(userInf -> !relatedUserInfList.contains(userInf)).collect(Collectors.toList());
|
//查询权限组的明细权限
|
QueryWrapper<PermitGroup> wrapper = Wrappers.query();
|
wrapper.eq("permit_group_id",permitGroupId);
|
List<PermitGroup> permitGroupList = mapper.selectList(wrapper);
|
|
resultMap.put("usersAdded",relatedUserInfList);
|
resultMap.put("usersNotAdded",notRelatedUserInfList);
|
resultMap.put("permits",permitGroupList);
|
return resultMap;
|
}
|
|
public List<PermitGroup> getPermitList() {
|
QueryWrapper<PermitGroup> wrapper = Wrappers.query();
|
wrapper.select("distinct permit_item_name");
|
|
List<PermitGroup> permitGroups = mapper.selectList(wrapper);
|
return permitGroups;
|
}
|
}
|