From 40bfb646d1b962d33841c1ebbceb0dd7cb668bfb Mon Sep 17 00:00:00 2001 From: liujie <1793218484@qq.com> Date: 星期二, 29 四月 2025 14:54:04 +0800 Subject: [PATCH] 后台日志管理 --- springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/service/impl/IdentityInformationServiceImpl.java | 135 ++++++++++++++++++++++++++++----------------- 1 files changed, 84 insertions(+), 51 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 ff15303..b3678da 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 @@ -1,6 +1,8 @@ package com.panzhihua.sangeshenbian.service.impl; +import cn.hutool.core.collection.CollectionUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.panzhihua.common.exceptions.ServiceException; import com.panzhihua.common.model.vos.LoginUserInfoVO; import com.panzhihua.common.redis.RedisUtils; import com.panzhihua.sangeshenbian.model.entity.PartyMember; @@ -22,6 +24,7 @@ private final ISystemUserService systemUserService; private final IPartyMemberService partyMemberService; private final RedisUtils redisUtils; + @Override public IdentityInformation getIdentityInformation(LoginUserInfoVO loginUserInfo) { // 获取党员信息 @@ -30,57 +33,68 @@ .eq(PartyMember::getDelFlag, 0)); // 获取管理员信息 - SystemUser systemUser = systemUserService.getSystemUserAdminByPhone(loginUserInfo.getPhone()).orElse(null); + SystemUser systemUser = systemUserService.lambdaQuery() + .eq(SystemUser::getPhone, loginUserInfo.getPhone()) + .eq(SystemUser::getIsAdmin, 1).last("LIMIT 1") + .ne(SystemUser::getStatus, 3) + .one(); // 获取身份 Integer identity = (Integer) redisUtils.get("identity:" + loginUserInfo.getPhone()); + // 权限列表 List<PermissionsVO> permissions = new ArrayList<>(); + IdentityInformation identityInformationVO = new IdentityInformation(); identityInformationVO.setPartyMember(partyMember); identityInformationVO.setSystemUser(systemUser); // 获取提示内容是否确认 Integer isConfirm = (Integer) redisUtils.get("confirmContent:" + loginUserInfo.getPhone()); - identityInformationVO.setIsConfirmContent(isConfirm !=null && isConfirm == 1); + identityInformationVO.setIsConfirmContent(isConfirm != null && isConfirm == 1); - if (partyMember != null) { - identityInformationVO.setIsFrozen(partyMember.getFreezeStatus() == 1); - } - if (systemUser != null) { - identityInformationVO.setIsFrozen(systemUser.getStatus() == 2); - } - - if (identity == null && systemUser != null) { - identityInformationVO.setIdentity(2); - redisUtils.set("identity:" + loginUserInfo.getPhone(), 2); - }else if (identity == null && partyMember != null){ - identityInformationVO.setIdentity(1); - redisUtils.set("identity:" + loginUserInfo.getPhone(), 1); - } - else { - identityInformationVO.setIdentity(identity); - } - - if (identityInformationVO.getIdentity() != null){ - if (identityInformationVO.getIdentity() == 1){ - identityInformationVO.setIsFrozen(partyMember !=null && partyMember.getFreezeStatus() == 1); - }else if (identityInformationVO.getIdentity() == 2){ - identityInformationVO.setIsFrozen(systemUser != null &&systemUser.getStatus() == 2); + // 获取当前身份 + if (identity == null){ + if (systemUser != null){ + identityInformationVO.setIdentity(2); + redisUtils.set("identity:" + loginUserInfo.getPhone(), 2); + }else if (partyMember != null && partyMember.getAuditStatus() == 1){ + identityInformationVO.setIdentity(1); + redisUtils.set("identity:" + loginUserInfo.getPhone(), 1); + }else { + identityInformationVO.setIdentity(null); } }else { + if (identity == 1 && (partyMember == null || partyMember.getAuditStatus() != 1)){ + identityInformationVO.setIdentity(null); + redisUtils.remove("identity:" + loginUserInfo.getPhone()); + }else if (identity == 2 && systemUser == null){ + identityInformationVO.setIdentity(null); + redisUtils.remove("identity:" + loginUserInfo.getPhone()); + }else { + identityInformationVO.setIdentity(identity); + } + } + + + + // 获取是否冻结 + if (identityInformationVO.getIdentity() != null) { + if (identityInformationVO.getIdentity() == 1) { + identityInformationVO.setIsFrozen(partyMember != null && partyMember.getFreezeStatus() == 1); + } else if (identityInformationVO.getIdentity() == 2) { + identityInformationVO.setIsFrozen(systemUser != null && systemUser.getStatus() == 2); + } + } else { identityInformationVO.setIsFrozen(false); } - + // 是否认证党员 identityInformationVO.setIsPartymember(partyMember != null && partyMember.getAuditStatus().equals(1)); + // 是否确认党员信息 identityInformationVO.setIsConfirm(partyMember != null && partyMember.getIsConfirm() == 1); + // 党员审核状态 identityInformationVO.setAuditStatus(partyMember == null ? null : partyMember.getAuditStatus()); - if (partyMember != null) { - PermissionsVO partyMemberPermissions = new PermissionsVO(); - partyMemberPermissions.setIdentity(1); - partyMemberPermissions.setName(String.format("%s%s", partyMember.getCommunity(), "党员")); - partyMemberPermissions.setIsFrozen(partyMember.getFreezeStatus() == 1); - permissions.add(partyMemberPermissions); - } + + // 封装管理员信息 if (systemUser != null) { Integer accountLevel = systemUser.getAccountLevel(); String districts = systemUser.getDistricts(); @@ -91,34 +105,53 @@ adminPermissions.setIsFrozen(systemUser.getStatus() == 2); if (accountLevel == 1) { adminPermissions.setName(String.format("%s%s", "攀枝花市", "管理员")); - } - if (accountLevel == 2) { + } else if (accountLevel == 2) { adminPermissions.setName(String.format("%s%s", districts, "管理员")); } else if (accountLevel == 3) { - adminPermissions.setIdentity(2); adminPermissions.setName(String.format("%s%s%s", districts, street, "管理员")); } else if (accountLevel == 4) { adminPermissions.setName(String.format("%s%s%s%s", districts, street, community, "管理员")); - adminPermissions.setIdentity(2); + } else { + adminPermissions.setName("未知"); } permissions.add(adminPermissions); + } + + // 封装党员信息 + if (partyMember != null && partyMember.getAuditStatus().equals(1)) { + PermissionsVO partyMemberPermissions = new PermissionsVO(); + partyMemberPermissions.setIdentity(1); + partyMemberPermissions.setName(String.format("%s%s", partyMember.getCommunity(), "党员")); + partyMemberPermissions.setIsFrozen(partyMember.getFreezeStatus() == 1); + permissions.add(partyMemberPermissions); } identityInformationVO.setPermissions(permissions); return identityInformationVO; } -// @Override -// public IdentityInformation getCurrentIdentityInformation(LoginUserInfoVO loginUserInfo) { -// if (identity == null && systemUser != null) { -// identityInformationVO.setIdentity(2); -// redisUtils.set("identity:" + loginUserInfo.getPhone(), 2); -// }else if (identity == null && partyMember != null){ -// identityInformationVO.setIdentity(1); -// redisUtils.set("identity:" + loginUserInfo.getPhone(), 1); -// } -// else { -// identityInformationVO.setIdentity(identity); -// } -// return null; -// } + + + @Override + public IdentityInformation getCurrentIdentityInformation(LoginUserInfoVO loginUserInfo) { + IdentityInformation identityInformation = getIdentityInformation(loginUserInfo); + Boolean isFrozen = identityInformation.getIsFrozen(); + if (isFrozen) { + throw new ServiceException("您的账号已被冻结,请联系管理员"); + } + List<PermissionsVO> permissions = identityInformation.getPermissions(); + if (CollectionUtil.isEmpty(permissions)){ + throw new ServiceException("请先完成认证"); + } + + SystemUser systemUser = identityInformation.getSystemUser(); + if (systemUser == null && identityInformation.getIdentity() == 2) { + throw new ServiceException("管理员信息不存在"); + } + + PartyMember partyMember = identityInformation.getPartyMember(); + if (partyMember == null && identityInformation.getIdentity() == 1) { + throw new ServiceException("党员信息不存在"); + } + return identityInformation; + } } -- Gitblit v1.7.1