luodangjia
2025-01-07 d0542b6f8b7ead9cea467f12d989eaabb8ec6e60
medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysRoleServiceImpl.java
@@ -1,5 +1,6 @@
package com.sinata.system.service.impl;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.sinata.common.annotation.DataScope;
@@ -12,6 +13,7 @@
import com.sinata.common.exception.ServiceException;
import com.sinata.common.utils.BeanUtils;
import com.sinata.common.utils.CollUtils;
import com.sinata.common.utils.DateUtils;
import com.sinata.common.utils.SecurityUtils;
import com.sinata.common.utils.StringUtils;
import com.sinata.common.utils.spring.SpringUtils;
@@ -465,14 +467,22 @@
    @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())) {
        if (Objects.isNull(sysRole.getRoleId())) {
            sysRole.setCreateBy(SecurityUtils.getUserId().toString());
            sysRole.setCreateTime(DateUtils.getNowDate());
            baseMapper.insert(sysRole);
        } else {
            // 删除角色与菜单关联
            roleMenuMapper.deleteRoleMenuByRoleId(sysRole.getRoleId());
            sysRole.setUpdateBy(SecurityUtils.getUserId().toString());
            sysRole.setUpdateTime(DateUtils.getNowDate());
            baseMapper.updateById(sysRole);
        }
        insertRoleMenu(sysRole);
    }
    /**
@@ -502,12 +512,15 @@
    @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);
        Long userId = loginUser.getUserId();
        SysUserRole sysUserRole = userRoleMapper.selectOne(Wrappers.lambdaQuery(SysUserRole.class).eq(SysUserRole::getUserId, userId).last("LIMIT 1"));
        if (Objects.nonNull(sysUserRole)) {
            SysRole role = this.getById(sysUserRole.getRoleId());
            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;
@@ -554,4 +567,15 @@
        // 获取当前的权限菜单(有层级)
        return this.getMenuLevelList(menusId);
    }
    /**
     * 角色列表
     *
     * @return
     */
    @Override
    public List<SysRoleVO> queryList() {
        List<SysRole> list = list();
        return BeanUtils.copyToList(list, SysRoleVO.class);
    }
}