From 1c940b2c9b9cb8f8591045e5048eac8de5923a14 Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期三, 04 十二月 2024 18:52:21 +0800 Subject: [PATCH] 系统管理:区域管理接口 --- medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java | 69 ++++++++++++++++++++++++++++++++++ 1 files changed, 69 insertions(+), 0 deletions(-) diff --git a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java index 998d382..cdb4916 100644 --- a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java +++ b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java @@ -7,6 +7,7 @@ import com.sinata.common.core.domain.entity.SysMenu; import com.sinata.common.core.domain.entity.SysRole; import com.sinata.common.core.domain.entity.SysUser; +import com.sinata.common.core.domain.model.LoginUser; import com.sinata.common.entity.PageDTO; import com.sinata.common.exception.ServiceException; import com.sinata.common.utils.BeanUtils; @@ -20,6 +21,7 @@ import com.sinata.system.domain.dto.SysRoleDTO; import com.sinata.system.domain.query.KeyWordQuery; import com.sinata.system.domain.vo.SysRoleVO; +import com.sinata.system.mapper.SysMenuMapper; import com.sinata.system.mapper.SysRoleDeptMapper; import com.sinata.system.mapper.SysRoleMapper; import com.sinata.system.mapper.SysRoleMenuMapper; @@ -59,6 +61,8 @@ private SysRoleDeptMapper roleDeptMapper; @Autowired private ISysMenuService menuService; + @Autowired + private SysMenuMapper menuMapper; /** * 根据条件分页查询角色数据 @@ -461,6 +465,9 @@ @Override public void saveRole(SysRoleDTO dto) { SysRole sysRole = BeanUtils.copyBean(dto, SysRole.class); + if (!this.checkRoleNameUnique(sysRole)) { + throw new ServiceException("保存角色'" + sysRole.getRoleName() + "'失败,角色名称已存在"); + } if (Objects.nonNull(sysRole.getRoleId())) { baseMapper.insert(sysRole); } else { @@ -485,4 +492,66 @@ } return sysRoleVO; } + + /** + * 获取当前登录用户可管理角色列表 + * + * @param loginUser + * @return + */ + @Override + public List<SysRoleVO> getManageRoleList(LoginUser loginUser) { + List<SysRoleVO> res = CollUtils.emptyList(); + Long roleId = loginUser.getUser().getRoleId(); + SysRole role = this.getById(roleId); + if (Objects.nonNull(role)) { + List<SysRole> list = this.lambdaQuery().in(SysRole::getRoleId, Arrays.asList(role.getManageRoleIdStr().split(","))).list(); + if (CollUtils.isNotEmpty(list)) { + res = BeanUtils.copyToList(list, SysRoleVO.class); + } + } + return res; + } + + @Override + public List<SysMenu> getMenuLevelList(List<Long> menusId) { + //获取当前的权限菜单 + List<SysMenu> all = menuMapper.getAllInIds(menusId); + // 第三级 + List<SysMenu> s3 = all.stream().filter(e -> e.getMenuType().equals("F")) + .collect(Collectors.toList()); + // 第二级 + List<SysMenu> s2 = all.stream().filter(e -> e.getMenuType().equals("C")) + .collect(Collectors.toList()); + // 第一级 + List<SysMenu> s1 = all.stream().filter(e -> e.getMenuType().equals("M")) + .collect(Collectors.toList()); + + for (SysMenu menu : s2) { + List<SysMenu> collect = s3.stream() + .filter(e -> e.getParentId().equals(menu.getMenuId())) + .collect(Collectors.toList()); + menu.setChildren(collect); + } + for (SysMenu menu : s1) { + List<SysMenu> collect = s2.stream() + .filter(e -> e.getParentId().equals(menu.getMenuId())) + .collect(Collectors.toList()); + menu.setChildren(collect); + } + return s1; + } + + @Override + public List<SysMenu> roleInfoFromUserId(Long userId) { + SysRole sysRole = roleMapper.selectRoleByUserId(userId); + // 获取当前角色的菜单列表 + List<SysMenu> menus = menuMapper.selectListByRoleId(sysRole.getRoleId()); + if (menus.size() == 0) { + return new ArrayList<>(); + } + List<Long> menusId = menus.stream().map(SysMenu::getMenuId).collect(Collectors.toList()); + // 获取当前的权限菜单(有层级) + return this.getMenuLevelList(menusId); + } } -- Gitblit v1.7.1