From be9179e444b22bf7d4b69c64745decd91696d67b Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期二, 06 五月 2025 19:28:48 +0800 Subject: [PATCH] 1.诉求新增录音 2.上级多角色调整 --- springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/IdentityInformationServiceImpl.java | 110 +++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 79 insertions(+), 31 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/IdentityInformationServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/IdentityInformationServiceImpl.java index b3678da..1503bb8 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/IdentityInformationServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/IdentityInformationServiceImpl.java @@ -5,9 +5,12 @@ import com.panzhihua.common.exceptions.ServiceException; import com.panzhihua.common.model.vos.LoginUserInfoVO; import com.panzhihua.common.redis.RedisUtils; +import com.panzhihua.sangeshenbian.model.dto.UserIdentityDTO; import com.panzhihua.sangeshenbian.model.entity.PartyMember; import com.panzhihua.sangeshenbian.model.entity.SystemUser; +import com.panzhihua.sangeshenbian.model.entity.SystemUserLevel; import com.panzhihua.sangeshenbian.service.IPartyMemberService; +import com.panzhihua.sangeshenbian.service.ISystemUserLevelService; import com.panzhihua.sangeshenbian.service.ISystemUserService; import com.panzhihua.sangeshenbian.service.IdentityInformationService; import com.panzhihua.sangeshenbian.warpper.IdentityInformation; @@ -17,6 +20,8 @@ import java.util.ArrayList; import java.util.List; +import java.util.Objects; +import java.util.Optional; @RequiredArgsConstructor @Service @@ -24,22 +29,24 @@ private final ISystemUserService systemUserService; private final IPartyMemberService partyMemberService; private final RedisUtils redisUtils; + private final ISystemUserLevelService systemUserLevelService; @Override public IdentityInformation getIdentityInformation(LoginUserInfoVO loginUserInfo) { + String phone = loginUserInfo.getPhone(); // 获取党员信息 PartyMember partyMember = partyMemberService.getOne(new LambdaQueryWrapper<PartyMember>() - .eq(PartyMember::getPhone, loginUserInfo.getPhone()) + .eq(PartyMember::getPhone, phone) .eq(PartyMember::getDelFlag, 0)); // 获取管理员信息 SystemUser systemUser = systemUserService.lambdaQuery() - .eq(SystemUser::getPhone, loginUserInfo.getPhone()) - .eq(SystemUser::getIsAdmin, 1).last("LIMIT 1") + .eq(SystemUser::getPhone, phone) + .last("LIMIT 1") .ne(SystemUser::getStatus, 3) .one(); // 获取身份 - Integer identity = (Integer) redisUtils.get("identity:" + loginUserInfo.getPhone()); + UserIdentityDTO userIdentityDTO = (UserIdentityDTO) redisUtils.get("identity:" + phone); // 权限列表 List<PermissionsVO> permissions = new ArrayList<>(); @@ -48,29 +55,40 @@ identityInformationVO.setSystemUser(systemUser); // 获取提示内容是否确认 - Integer isConfirm = (Integer) redisUtils.get("confirmContent:" + loginUserInfo.getPhone()); + Integer isConfirm = (Integer) redisUtils.get("confirmContent:" + phone); identityInformationVO.setIsConfirmContent(isConfirm != null && isConfirm == 1); // 获取当前身份 - if (identity == null){ + if (userIdentityDTO == null){ if (systemUser != null){ - identityInformationVO.setIdentity(2); - redisUtils.set("identity:" + loginUserInfo.getPhone(), 2); + handleSystemUserLevelId(phone, systemUser, 2, identityInformationVO); }else if (partyMember != null && partyMember.getAuditStatus() == 1){ identityInformationVO.setIdentity(1); - redisUtils.set("identity:" + loginUserInfo.getPhone(), 1); + UserIdentityDTO build = UserIdentityDTO.builder().identity(1).build(); + redisUtils.set("identity:" + phone, build); }else { identityInformationVO.setIdentity(null); } }else { + Integer identity = userIdentityDTO.getIdentity(); if (identity == 1 && (partyMember == null || partyMember.getAuditStatus() != 1)){ identityInformationVO.setIdentity(null); - redisUtils.remove("identity:" + loginUserInfo.getPhone()); + redisUtils.remove("identity:" + phone); }else if (identity == 2 && systemUser == null){ identityInformationVO.setIdentity(null); - redisUtils.remove("identity:" + loginUserInfo.getPhone()); + redisUtils.remove("identity:" + phone); }else { - identityInformationVO.setIdentity(identity); + Integer levelId = userIdentityDTO.getLevelId(); + //验证账号所属层级 + SystemUserLevel userLevel = systemUserLevelService.getById(levelId); + if (Objects.isNull(userLevel)) { + handleSystemUserLevelId(phone, systemUser, identity, identityInformationVO); + } else { + identityInformationVO.setLevelId(levelId); + identityInformationVO.setSuperviseFlag(userLevel.getSuperviseFlag()); + identityInformationVO.setIdentity(identity); + identityInformationVO.setSystemUserLevel(userLevel); + } } } @@ -96,25 +114,28 @@ // 封装管理员信息 if (systemUser != null) { - Integer accountLevel = systemUser.getAccountLevel(); - String districts = systemUser.getDistricts(); - String street = systemUser.getStreet(); - String community = systemUser.getCommunity(); - PermissionsVO adminPermissions = new PermissionsVO(); - adminPermissions.setIdentity(2); - adminPermissions.setIsFrozen(systemUser.getStatus() == 2); - if (accountLevel == 1) { - adminPermissions.setName(String.format("%s%s", "攀枝花市", "管理员")); - } else if (accountLevel == 2) { - adminPermissions.setName(String.format("%s%s", districts, "管理员")); - } else if (accountLevel == 3) { - adminPermissions.setName(String.format("%s%s%s", districts, street, "管理员")); - } else if (accountLevel == 4) { - adminPermissions.setName(String.format("%s%s%s%s", districts, street, community, "管理员")); - } else { - adminPermissions.setName("未知"); + List<SystemUserLevel> userLevels = systemUserLevelService.getListBySystemUserId(systemUser.getId()); + for (SystemUserLevel userLevel : userLevels) { + Integer accountLevel = userLevel.getLevel(); + String districts = userLevel.getDistricts(); + String street = userLevel.getStreet(); + String community = userLevel.getCommunity(); + PermissionsVO adminPermissions = new PermissionsVO(); + adminPermissions.setIdentity(2); + adminPermissions.setIsFrozen(systemUser.getStatus() == 2); + if (accountLevel == 1) { + adminPermissions.setName(String.format("%s%s", "攀枝花市", "管理员")); + } else if (accountLevel == 2) { + adminPermissions.setName(String.format("%s%s", districts, "管理员")); + } else if (accountLevel == 3) { + adminPermissions.setName(String.format("%s%s%s", districts, street, "管理员")); + } else if (accountLevel == 4) { + adminPermissions.setName(String.format("%s%s%s%s", districts, street, community, "管理员")); + } else { + adminPermissions.setName("未知"); + } + permissions.add(adminPermissions); } - permissions.add(adminPermissions); } // 封装党员信息 @@ -129,6 +150,30 @@ return identityInformationVO; } + /** + * 处理管理员所属层级 + * @param phone + * @param systemUser + * @param identity + * @param identityInformationVO + */ + private void handleSystemUserLevelId(String phone, SystemUser systemUser, Integer identity, IdentityInformation identityInformationVO) { + SystemUserLevel userLevel; + //当前所属层级不存在,默认为第一个添加的层级 + Optional<SystemUserLevel> levelOptional = systemUserLevelService.getByLevelByUserId(systemUser.getId()); + if (levelOptional.isPresent()) { + userLevel = levelOptional.get(); + UserIdentityDTO build = UserIdentityDTO.builder().identity(identity).levelId(userLevel.getId()).build(); + redisUtils.set("identity:" + phone, build); + identityInformationVO.setIdentity(identity); + identityInformationVO.setLevelId(userLevel.getId()); + identityInformationVO.setSuperviseFlag(userLevel.getSuperviseFlag()); + identityInformationVO.setSystemUserLevel(userLevel); + } else { + //当前账号没有管理员账号所属层级,清空账号当前层级信息 + redisUtils.remove("identity:" + phone); + } + } @Override @@ -147,7 +192,10 @@ if (systemUser == null && identityInformation.getIdentity() == 2) { throw new ServiceException("管理员信息不存在"); } - + SystemUserLevel systemUserLevel = identityInformation.getSystemUserLevel(); + if (systemUserLevel == null && identityInformation.getIdentity() == 2) { + throw new ServiceException("管理员所属层级不存在"); + } PartyMember partyMember = identityInformation.getPartyMember(); if (partyMember == null && identityInformation.getIdentity() == 1) { throw new ServiceException("党员信息不存在"); -- Gitblit v1.7.1