如果角色存在用户关联 就不能禁用此角色

pro
wangwei 2 years ago
parent fde36ac636
commit b9738be229

@ -88,6 +88,13 @@ public class SysRoleController extends BaseController {
@PutMapping @PutMapping
@Log(title = "用户管理", businessType = BusinessType.UPDATE) @Log(title = "用户管理", businessType = BusinessType.UPDATE)
public BaseResponse edit(@Validated @RequestBody SysRole role) { public BaseResponse edit(@Validated @RequestBody SysRole role) {
//把角色改成禁用的时候 如果存在关联 不能禁用
if("1".equals(role.getStatus())){
List<SysUserRole> sysUserRoles = roleService.selectUserRoleList(role.getRoleId());
if( !sysUserRoles.isEmpty()){
return ResultVOUtils.error(500, "角色已关联用户,不能禁用!");
}
}
roleService.checkRoleAllowed(role); roleService.checkRoleAllowed(role);
roleService.checkRoleDataScope(role.getRoleId()); roleService.checkRoleDataScope(role.getRoleId());
if (Constant.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) { if (Constant.NOT_UNIQUE.equals(roleService.checkRoleNameUnique(role))) {

@ -19,4 +19,6 @@ public interface SysUserRoleMapper {
SysUserRole selectByAuthId(Long id); SysUserRole selectByAuthId(Long id);
List<SysUserRole> selectUserRoleList(Long roleId);
} }

@ -85,6 +85,8 @@ public interface ISysRoleService {
*/ */
void checkRoleAllowed(SysRole role); void checkRoleAllowed(SysRole role);
List<SysUserRole> selectUserRoleList(Long roleId);
/** /**
* *
* *

@ -187,6 +187,11 @@ public class SysRoleServiceImpl implements ISysRoleService {
} }
} }
@Override
public List<SysUserRole> selectUserRoleList(Long roleId) {
return sysUserRoleMapper.selectUserRoleList(roleId);
}
/** /**
* *
* *

@ -20,6 +20,13 @@
where user_id=#{id} where user_id=#{id}
</select> </select>
<select id="selectUserRoleList" resultMap="SysUserRoleResult">
select *
from auth_user_role
where role_id = #{roleId}
</select>
<delete id="delete" parameterType="com.glxp.api.req.auth.FilterUserRoleRequest"> <delete id="delete" parameterType="com.glxp.api.req.auth.FilterUserRoleRequest">
DELETE DELETE

Loading…
Cancel
Save