|
|
|
@ -22,7 +22,9 @@ import org.dromara.common.core.utils.*;
|
|
|
|
import org.dromara.common.mybatis.core.page.PageQuery;
|
|
|
|
import org.dromara.common.mybatis.core.page.PageQuery;
|
|
|
|
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
|
|
|
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
|
|
|
import org.dromara.common.satoken.utils.LoginHelper;
|
|
|
|
import org.dromara.common.satoken.utils.LoginHelper;
|
|
|
|
import org.dromara.system.domain.*;
|
|
|
|
import org.dromara.system.domain.SysUser;
|
|
|
|
|
|
|
|
import org.dromara.system.domain.SysUserPost;
|
|
|
|
|
|
|
|
import org.dromara.system.domain.SysUserRole;
|
|
|
|
import org.dromara.system.domain.bo.SysUserBo;
|
|
|
|
import org.dromara.system.domain.bo.SysUserBo;
|
|
|
|
import org.dromara.system.domain.vo.SysPostVo;
|
|
|
|
import org.dromara.system.domain.vo.SysPostVo;
|
|
|
|
import org.dromara.system.domain.vo.SysRoleVo;
|
|
|
|
import org.dromara.system.domain.vo.SysRoleVo;
|
|
|
|
@ -454,23 +456,25 @@ public class SysUserServiceImpl implements ISysUserService, UserService {
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
List<Long> postIds = Arrays.asList(postIdArr);
|
|
|
|
List<Long> postIds = Arrays.asList(postIdArr);
|
|
|
|
// 判断是否具有此角色的操作权限
|
|
|
|
|
|
|
|
List<SysPostVo> posts = postMapper.selectPostList(
|
|
|
|
// 校验是否有权限操作这些岗位(含数据权限控制)
|
|
|
|
new LambdaQueryWrapper<SysPost>().in(SysPost::getPostId, postIds));
|
|
|
|
if (postMapper.selectPostCount(postIds) != postIds.size()) {
|
|
|
|
if (CollUtil.isEmpty(posts) || posts.size() != postIds.size()) {
|
|
|
|
|
|
|
|
throw new ServiceException("没有权限访问岗位的数据");
|
|
|
|
throw new ServiceException("没有权限访问岗位的数据");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 是否清除旧的用户岗位绑定
|
|
|
|
if (clear) {
|
|
|
|
if (clear) {
|
|
|
|
// 删除用户与岗位关联
|
|
|
|
|
|
|
|
userPostMapper.delete(new LambdaQueryWrapper<SysUserPost>().eq(SysUserPost::getUserId, user.getUserId()));
|
|
|
|
userPostMapper.delete(new LambdaQueryWrapper<SysUserPost>().eq(SysUserPost::getUserId, user.getUserId()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// 新增用户与岗位管理
|
|
|
|
|
|
|
|
List<SysUserPost> list = StreamUtils.toList(postIds, postId -> {
|
|
|
|
// 构建用户岗位关联列表并批量插入
|
|
|
|
SysUserPost up = new SysUserPost();
|
|
|
|
List<SysUserPost> list = StreamUtils.toList(postIds,
|
|
|
|
up.setUserId(user.getUserId());
|
|
|
|
postId -> {
|
|
|
|
up.setPostId(postId);
|
|
|
|
SysUserPost up = new SysUserPost();
|
|
|
|
return up;
|
|
|
|
up.setUserId(user.getUserId());
|
|
|
|
});
|
|
|
|
up.setPostId(postId);
|
|
|
|
|
|
|
|
return up;
|
|
|
|
|
|
|
|
});
|
|
|
|
userPostMapper.insertBatch(list);
|
|
|
|
userPostMapper.insertBatch(list);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@ -482,30 +486,36 @@ public class SysUserServiceImpl implements ISysUserService, UserService {
|
|
|
|
* @param clear 清除已存在的关联数据
|
|
|
|
* @param clear 清除已存在的关联数据
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
private void insertUserRole(Long userId, Long[] roleIds, boolean clear) {
|
|
|
|
private void insertUserRole(Long userId, Long[] roleIds, boolean clear) {
|
|
|
|
if (ArrayUtil.isNotEmpty(roleIds)) {
|
|
|
|
if (ArrayUtil.isEmpty(roleIds)) {
|
|
|
|
List<Long> roleList = new ArrayList<>(List.of(roleIds));
|
|
|
|
return;
|
|
|
|
if (!LoginHelper.isSuperAdmin(userId)) {
|
|
|
|
}
|
|
|
|
roleList.remove(SystemConstants.SUPER_ADMIN_ID);
|
|
|
|
|
|
|
|
}
|
|
|
|
List<Long> roleList = new ArrayList<>(Arrays.asList(roleIds));
|
|
|
|
// 判断是否具有此角色的操作权限
|
|
|
|
|
|
|
|
List<SysRoleVo> roles = roleMapper.selectRoleList(
|
|
|
|
// 非超级管理员,禁止包含超级管理员角色
|
|
|
|
new LambdaQueryWrapper<SysRole>().in(SysRole::getRoleId, roleList));
|
|
|
|
if (!LoginHelper.isSuperAdmin(userId)) {
|
|
|
|
if (CollUtil.isEmpty(roles) || roles.size() != roleList.size()) {
|
|
|
|
roleList.remove(SystemConstants.SUPER_ADMIN_ID);
|
|
|
|
throw new ServiceException("没有权限访问角色的数据");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (clear) {
|
|
|
|
// 校验是否有权限访问这些角色(含数据权限控制)
|
|
|
|
// 删除用户与角色关联
|
|
|
|
if (roleMapper.selectRoleCount(roleList) != roleList.size()) {
|
|
|
|
userRoleMapper.delete(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId, userId));
|
|
|
|
throw new ServiceException("没有权限访问角色的数据");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// 新增用户与角色管理
|
|
|
|
|
|
|
|
List<SysUserRole> list = StreamUtils.toList(roleList, roleId -> {
|
|
|
|
// 是否清除原有绑定
|
|
|
|
|
|
|
|
if (clear) {
|
|
|
|
|
|
|
|
userRoleMapper.delete(new LambdaQueryWrapper<SysUserRole>().eq(SysUserRole::getUserId, userId));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 批量插入用户-角色关联
|
|
|
|
|
|
|
|
List<SysUserRole> list = StreamUtils.toList(roleList,
|
|
|
|
|
|
|
|
roleId -> {
|
|
|
|
SysUserRole ur = new SysUserRole();
|
|
|
|
SysUserRole ur = new SysUserRole();
|
|
|
|
ur.setUserId(userId);
|
|
|
|
ur.setUserId(userId);
|
|
|
|
ur.setRoleId(roleId);
|
|
|
|
ur.setRoleId(roleId);
|
|
|
|
return ur;
|
|
|
|
return ur;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
userRoleMapper.insertBatch(list);
|
|
|
|
userRoleMapper.insertBatch(list);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
|