From dc9239d73b15b9a51c46a9e8d25c0d4400e613ce Mon Sep 17 00:00:00 2001
From: luodangjia <luodangjia>
Date: 星期一, 29 七月 2024 09:17:54 +0800
Subject: [PATCH] 7.29

---
 ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/RoleController.java |   25 +++++++++++++++++++++----
 1 files changed, 21 insertions(+), 4 deletions(-)

diff --git a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/RoleController.java b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/RoleController.java
index 0f40da3..938846c 100644
--- a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/RoleController.java
+++ b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/RoleController.java
@@ -7,12 +7,15 @@
 import com.ruoyi.admin.entity.Menu;
 import com.ruoyi.admin.entity.Role;
 import com.ruoyi.admin.entity.RoleMenu;
+import com.ruoyi.admin.entity.SysUser;
 import com.ruoyi.admin.request.RoleRequest;
 import com.ruoyi.admin.service.MenuService;
 import com.ruoyi.admin.service.RoleMenuService;
 import com.ruoyi.admin.service.RoleService;
+import com.ruoyi.admin.service.SysUserService;
 import com.ruoyi.admin.vo.RoleDetailVO;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.security.annotation.RequiresPermissions;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.system.api.model.LoginUser;
 import io.swagger.annotations.Api;
@@ -47,6 +50,8 @@
     private RoleMenuService roleMenuService;
     @Resource
     private MenuService menuService;
+    @Resource
+    private SysUserService userService;
 
 
     /**
@@ -55,6 +60,7 @@
      * @param pageNum  页码
      * @param pageSize 每页显示条数
      */
+    @RequiresPermissions("power_role")
     @ApiOperation(value = "角色分页查询列表", tags = {"后台-权限管理-角色管理"})
     @GetMapping(value = "/page")
     @ApiImplicitParams({
@@ -70,6 +76,7 @@
     /**
      * 角色列表
      */
+    @RequiresPermissions("power_role")
     @ApiOperation(value = "角色列表", tags = {"后台-权限管理-账号管理"})
     @GetMapping(value = "/list")
     public R<List<Role>> list() {
@@ -105,6 +112,7 @@
      *
      * @param roleRequest 角色信息
      */
+    @RequiresPermissions("role_update")
     @ApiOperation(value = "编辑角色", tags = {"后台-权限管理-角色管理"})
     @PostMapping(value = "/update")
     public R<RoleDetailVO> update(@RequestBody RoleRequest roleRequest) {
@@ -129,6 +137,7 @@
      *
      * @param roleRequest 角色信息
      */
+    @RequiresPermissions("role_save")
     @ApiOperation(value = "新增角色", tags = {"后台-权限管理-角色管理"})
     @PostMapping(value = "/save")
     public R<String> save(@RequestBody RoleRequest roleRequest) {
@@ -144,6 +153,7 @@
      *
      * @param ids 角色id拼接
      */
+    @RequiresPermissions("role_delete")
     @ApiOperation(value = "批量删除角色", tags = {"后台-权限管理-角色管理"})
     @GetMapping(value = "/batchDelete")
     @ApiImplicitParams({
@@ -151,11 +161,18 @@
     })
     public R<String> batchDelete(@RequestParam String ids) {
         List<String> idList = Arrays.stream(ids.split(",")).collect(Collectors.toList());
+        // 判断角色是否已存在关联账号
         List<Role> list = roleService.lambdaQuery().in(Role::getRoleId, idList).list();
-        list.forEach(data -> data.setDelFlag("2"));
-        // 删除角色需要删除角色所关联的菜单信息
-        for (String id : idList) {
-            roleMenuService.remove(new QueryWrapper<RoleMenu>().eq("role_id", id));
+        for (Role role : list) {
+            Long roleId = role.getRoleId();
+            List<SysUser> sysUserList = userService.lambdaQuery()
+                    .eq(SysUser::getRoleId, roleId)
+                    .eq(SysUser::getIsDelete, 0).list();
+            if (sysUserList.isEmpty()) {
+                role.setDelFlag("2");
+            }
+            // 删除菜单关联信息
+            roleMenuService.remove(new QueryWrapper<RoleMenu>().eq("role_id", roleId));
         }
         return roleService.updateBatchById(list) ? R.ok() : R.fail();
     }

--
Gitblit v1.7.1