You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

264 lines
10 KiB

/**
* BladeX Commercial License Agreement
* Copyright (c) 2018-2099, https://bladex.cn. All rights reserved.
* <p>
* Use of this software is governed by the Commercial License Agreement
* obtained after purchasing a license from BladeX.
* <p>
* 1. This software is for development use only under a valid license
* from BladeX.
* <p>
* 2. Redistribution of this software's source code to any third party
* without a commercial license is strictly prohibited.
* <p>
* 3. Licensees may copyright their own code but cannot use segments
* from this software for such purposes. Copyright of this software
* remains with BladeX.
* <p>
* Using this software signifies agreement to this License, and the software
* must not be used for illegal purposes.
* <p>
* THIS SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY. The author is
* not liable for any claims arising from secondary or illegal development.
* <p>
* Author: Chill Zhuang (bladejava@qq.com)
*/
package com.nov.KgLowDurable.service.Impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.nov.KgLowDurable.constant.RoleConstant;
import com.nov.KgLowDurable.exception.CustomerException;
import com.nov.KgLowDurable.mapper.RoleMapper;
import com.nov.KgLowDurable.pojo.entity.Role;
import com.nov.KgLowDurable.pojo.entity.RoleMenu;
import com.nov.KgLowDurable.pojo.vo.RoleVO;
import com.nov.KgLowDurable.service.IRoleMenuService;
import com.nov.KgLowDurable.service.IRoleService;
import com.nov.KgLowDurable.util.BladeConstant;
import com.nov.KgLowDurable.util.ForestNodeMerger;
import com.nov.KgLowDurable.util.Func;
import com.nov.KgLowDurable.wrapper.RoleWrapper;
import lombok.AllArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.validation.annotation.Validated;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import static com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isNotEmpty;
import static com.nov.KgLowDurable.util.Condition.isEmpty;
/**
* 服务实现类
*
* @author Chill
*/
//@Master
@Service
@Validated
@AllArgsConstructor
public class RoleServiceImpl extends ServiceImpl<RoleMapper, Role> implements IRoleService {
private final IRoleMenuService roleMenuService;
//private final IRoleScopeService roleScopeService;
@Override
public IPage<RoleVO> selectRolePage(IPage<RoleVO> page, RoleVO role) {
return page.setRecords(baseMapper.selectRolePage(page, role));
}
@Override
public List<RoleVO> tree(String tenantId) {
// String userRole = AuthUtil.getUserRole();
String excludeRole = null;
// if (!CollectionUtil.contains(Func.toStrArray(userRole), RoleConstant.ADMIN) && !CollectionUtil.contains(Func.toStrArray(userRole), RoleConstant.ADMINISTRATOR)) {
// excludeRole = RoleConstant.ADMIN;
// }
return ForestNodeMerger.merge(baseMapper.tree(tenantId, excludeRole));
}
@Override
@Transactional(rollbackFor = Exception.class)
public boolean grant( List<Long> roleIds, List<Long> menuIds, List<Long> dataScopeIds, List<Long> apiScopeIds) {
return grantRoleMenu(roleIds, menuIds); //&& grantDataScope(roleIds, dataScopeIds) && grantApiScope(roleIds, apiScopeIds);
}
private boolean grantRoleMenu(List<Long> roleIds, List<Long> menuIds) {
// 防止越权配置超管角色
Integer administratorCount = baseMapper.selectCount(Wrappers.<Role>query().lambda().eq(Role::getRoleAlias, RoleConstant.ADMINISTRATOR).in(Role::getId, roleIds));
if (administratorCount > 0L) {
//throw new Exception("无权配置超管角色!");
}
// 防止越权配置管理员角色
Integer adminCount = baseMapper.selectCount(Wrappers.<Role>query().lambda().eq(Role::getRoleAlias, RoleConstant.ADMIN).in(Role::getId, roleIds));
if ( adminCount > 0L) {
//throw new ServiceException("无权配置管理员角色!");
}
// 删除角色配置的菜单集合
roleMenuService.remove(Wrappers.<RoleMenu>update().lambda().in(RoleMenu::getRoleId, roleIds));
// 组装配置
List<RoleMenu> roleMenus = new ArrayList<>();
roleIds.forEach(roleId -> menuIds.forEach(menuId -> {
RoleMenu roleMenu = new RoleMenu();
roleMenu.setRoleId(roleId);
roleMenu.setMenuId(menuId);
roleMenus.add(roleMenu);
}));
// 新增配置
roleMenuService.saveBatch(roleMenus);
// 递归设置下属角色菜单集合
recursionRoleMenu(roleIds, menuIds);
return true;
}
private void recursionRoleMenu(List<Long> roleIds, List<Long> menuIds) {
roleIds.forEach(roleId -> baseMapper.selectList(Wrappers.<Role>query().lambda().eq(Role::getParentId, roleId)).forEach(role -> {
List<RoleMenu> roleMenuList = roleMenuService.list(Wrappers.<RoleMenu>query().lambda().eq(RoleMenu::getRoleId, role.getId()));
// 子节点过滤出父节点删除的菜单集合
List<Long> collectRoleMenuIds = roleMenuList.stream().map(RoleMenu::getMenuId).filter(menuId -> !menuIds.contains(menuId)).collect(Collectors.toList());
if (collectRoleMenuIds.size() > 0) {
// 删除子节点权限外的菜单集合
roleMenuService.remove(Wrappers.<RoleMenu>update().lambda().eq(RoleMenu::getRoleId, role.getId()).in(RoleMenu::getMenuId, collectRoleMenuIds));
// 递归设置下属角色菜单集合
recursionRoleMenu(Collections.singletonList(role.getId()), menuIds);
}
}));
}
// private boolean grantDataScope(List<Long> roleIds, List<Long> dataScopeIds) {
// // 删除角色配置的数据权限集合
// roleScopeService.remove(Wrappers.<RoleScope>update().lambda().eq(RoleScope::getScopeCategory, DATA_SCOPE_CATEGORY).in(RoleScope::getRoleId, roleIds));
// // 组装配置
// List<RoleScope> roleDataScopes = new ArrayList<>();
// roleIds.forEach(roleId -> dataScopeIds.forEach(scopeId -> {
// RoleScope roleScope = new RoleScope();
// roleScope.setScopeCategory(DATA_SCOPE_CATEGORY);
// roleScope.setRoleId(roleId);
// roleScope.setScopeId(scopeId);
// roleDataScopes.add(roleScope);
// }));
// // 新增配置
// roleScopeService.saveBatch(roleDataScopes);
// return true;
// }
// private boolean grantApiScope(List<Long> roleIds, List<Long> apiScopeIds) {
// // 删除角色配置的接口权限集合
// roleScopeService.remove(Wrappers.<RoleScope>update().lambda().eq(RoleScope::getScopeCategory, API_SCOPE_CATEGORY).in(RoleScope::getRoleId, roleIds));
// // 组装配置
// List<RoleScope> roleApiScopes = new ArrayList<>();
// roleIds.forEach(roleId -> apiScopeIds.forEach(scopeId -> {
// RoleScope roleScope = new RoleScope();
// roleScope.setScopeCategory(API_SCOPE_CATEGORY);
// roleScope.setScopeId(scopeId);
// roleScope.setRoleId(roleId);
// roleApiScopes.add(roleScope);
// }));
// // 新增配置
// roleScopeService.saveBatch(roleApiScopes);
// return true;
// }
@Override
public String getRoleIds(String tenantId, String roleNames) {
List<Role> roleList = baseMapper.selectList(Wrappers.<Role>query().lambda().eq(Role::getTenantId, tenantId).in(Role::getRoleName, Func.toStrList(roleNames)));
if (roleList != null && roleList.size() > 0) {
return roleList.stream().map(role -> Func.toStr(role.getId())).distinct().collect(Collectors.joining(","));
}
return null;
}
@Override
public List<String> getRoleNames(String roleIds) {
return baseMapper.getRoleNames(Func.toLongArray(roleIds));
}
@Override
public List<String> getRoleAliases(String roleIds) {
return baseMapper.getRoleAliases(Func.toLongArray(roleIds));
}
@Override
public boolean submit(Role role) {
// if (!AuthUtil.isAdministrator()) {
// if (Func.toStr(role.getRoleAlias()).equals(RoleConstant.ADMINISTRATOR)) {
// throw new ServiceException("无权限创建超管角色!");
// }
// }
if (isEmpty(role.getParentId())) {
//role.setTenantId(AuthUtil.getTenantId());
role.setParentId(BladeConstant.TOP_PARENT_ID);
}
if (role.getParentId() > 0) {
Role parent = getById(role.getParentId());
// if (Func.toLong(role.getParentId()) == Func.toLong(role.getId())) {
// throw new ServiceException("父节点不可选择自身!");
// }
role.setTenantId(parent.getTenantId());
}
role.setIsDeleted(BladeConstant.DB_NOT_DELETED);
return saveOrUpdate(role);
}
@Override
public List<RoleVO> search(String roleName, Long parentId) {
//String tenantId = AuthUtil.getTenantId();
LambdaQueryWrapper<Role> queryWrapper = Wrappers.<Role>query().lambda();
if (isNotEmpty(roleName)) {
queryWrapper.like(Role::getRoleName, roleName);
}
if (isNotEmpty(parentId) && parentId > 0L) {
queryWrapper.eq(Role::getParentId, parentId);
}
// if (Func.isNotEmpty(tenantId)) {
// queryWrapper.eq(Role::getTenantId, tenantId);
// }
List<Role> roleList = baseMapper.selectList(queryWrapper);
return RoleWrapper.build().listNodeVO(roleList);
}
@Override
public boolean removeRole(String ids) {
Integer cnt = baseMapper.selectCount(Wrappers.<Role>query().lambda().in(Role::getParentId, Func.toLongList(ids)));
if (cnt > 0L) {
throw new CustomerException("请先删除子节点!");
}
return removeByIds(Func.toLongList(ids));
}
@Override
4 months ago
public List<Role> alias() {
// 获取所有角色数据
4 months ago
List<Role> roles = baseMapper.selectList(Wrappers.<Role>lambdaQuery());
// 根据 roleAlias 对角色进行分组
Map<String, List<String>> aliasToNamesMap = roles.stream()
.collect(Collectors.groupingBy(Role::getRoleAlias,
Collectors.mapping(Role::getRoleName, Collectors.toList())));
// 创建新的角色列表,每个角色的 roleName 是 roleAlias 后跟括号内的所有 roleName
return aliasToNamesMap.entrySet().stream()
// 过滤掉超级管理员角色
.filter(entry -> !RoleConstant.ADMINISTRATOR.equals(entry.getKey()))
.map(entry -> {
String roleAlias = entry.getKey();
List<String> names = entry.getValue();
String namesConcat = names.stream().distinct().collect(Collectors.joining(StringPool.COMMA + StringPool.SPACE));
Role role = new Role();
role.setRoleAlias(roleAlias);
role.setRoleName(roleAlias + StringPool.SPACE + StringPool.LEFT_BRACKET + namesConcat + StringPool.RIGHT_BRACKET);
return role;
}).collect(Collectors.toList());
}
}