From 778676c8da2ce6157fbbcdb098099092c74d32da Mon Sep 17 00:00:00 2001 From: shiziyuan9527 Date: Wed, 28 Dec 2022 17:07:42 +0800 Subject: [PATCH] =?UTF-8?q?refactor(=E7=94=A8=E6=88=B7=E7=BB=84=E4=B8=8E?= =?UTF-8?q?=E6=9D=83=E9=99=90):=20=E6=9D=83=E9=99=90=E8=B5=84=E6=BA=90?= =?UTF-8?q?=E7=9A=84=E5=8A=A0=E8=BD=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../io/metersphere/service/GroupService.java | 35 ++++++++++--------- 1 file changed, 18 insertions(+), 17 deletions(-) diff --git a/system-setting/backend/src/main/java/io/metersphere/service/GroupService.java b/system-setting/backend/src/main/java/io/metersphere/service/GroupService.java index 82f4449155..65643ac2c3 100644 --- a/system-setting/backend/src/main/java/io/metersphere/service/GroupService.java +++ b/system-setting/backend/src/main/java/io/metersphere/service/GroupService.java @@ -200,7 +200,7 @@ public class GroupService { private GroupJson loadPermissionJsonFromService() { GroupJson groupJson = null; - List globalResource = new ArrayList<>(); + List globalResources = new ArrayList<>(); try { for (String service : servicePermissionLoadOrder) { Object obj = stringRedisTemplate.opsForHash().get(RedisKey.MS_PERMISSION_KEY, service); @@ -208,25 +208,26 @@ public class GroupService { LogUtil.warn("permission json file is null. service name: " + service); continue; } - GroupJson temp = JSON.parseObject((String) obj, GroupJson.class); + GroupJson microServiceGroupJson = JSON.parseObject((String) obj, GroupJson.class); + List globalResource = microServiceGroupJson.getResource() + .stream() + .filter(gp -> BooleanUtils.isTrue(gp.isGlobal())) + .collect(Collectors.toList()); + if (CollectionUtils.isNotEmpty(globalResource)) { + globalResources.addAll(globalResource); + microServiceGroupJson.getResource().removeIf(gp -> BooleanUtils.isTrue(gp.isGlobal())); + } + if (groupJson == null) { - groupJson = temp; - // 全局权限放系统设置模块 - if (StringUtils.equals(service, MicroServiceName.SYSTEM_SETTING)) { - globalResource = temp.getResource() - .stream() - .filter(gp -> BooleanUtils.isTrue(gp.isGlobal())) - .collect(Collectors.toList()); - temp.getResource().removeIf(gp -> BooleanUtils.isTrue(gp.isGlobal())); - } + groupJson = microServiceGroupJson; } else { - groupJson.getResource().addAll(temp.getResource()); - groupJson.getPermissions().addAll(temp.getPermissions()); + groupJson.getResource().addAll(microServiceGroupJson.getResource()); + groupJson.getPermissions().addAll(microServiceGroupJson.getPermissions()); } } - // 拼装权限的时候放在最后 - if (groupJson != null && !globalResource.isEmpty()) { - groupJson.getResource().addAll(globalResource); + // 拼装时通用权限Resource放在最后 + if (groupJson != null && !globalResources.isEmpty()) { + groupJson.getResource().addAll(globalResources); } } catch (Exception e) { LogUtil.error(e); @@ -337,7 +338,7 @@ public class GroupService { } else { grs = resources .stream() - .filter(g -> g.getId().startsWith(group.getType()) || g.getId().startsWith(PERSONAL_PREFIX)) + .filter(g -> g.getId().startsWith(group.getType()) || BooleanUtils.isTrue(g.isGlobal())) .collect(Collectors.toList()); permissions.forEach(p -> { if (permissionList.contains(p.getId())) {