From d671f1e6611902e2e4d59443f556c421dfc999d7 Mon Sep 17 00:00:00 2001 From: kaiyu <404897439@qq.com> Date: Wed, 09 Jun 2021 11:36:49 +0800 Subject: [PATCH] screen-manage 更新后台账号更新角色日志逻辑 --- screen-manage/src/main/java/com/moral/api/service/ManageRoleService.java | 2 + screen-manage/src/main/java/com/moral/api/service/impl/ManageAccountRoleServiceImpl.java | 56 +++++++++++++++++++++++++++ screen-manage/src/main/java/com/moral/api/entity/ManageAccountRole.java | 6 ++- screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java | 16 ++++++++ 4 files changed, 77 insertions(+), 3 deletions(-) diff --git a/screen-manage/src/main/java/com/moral/api/entity/ManageAccountRole.java b/screen-manage/src/main/java/com/moral/api/entity/ManageAccountRole.java index 8522a8a..930396a 100644 --- a/screen-manage/src/main/java/com/moral/api/entity/ManageAccountRole.java +++ b/screen-manage/src/main/java/com/moral/api/entity/ManageAccountRole.java @@ -5,6 +5,8 @@ import com.baomidou.mybatisplus.annotation.TableId; import java.time.LocalDateTime; import java.io.Serializable; +import java.util.Date; + import lombok.Data; import lombok.EqualsAndHashCode; @@ -41,12 +43,12 @@ /** * ������������ */ - private LocalDateTime createTime; + private Date createTime; /** * ������������ */ - private LocalDateTime updateTime; + private Date updateTime; /** * ������������ diff --git a/screen-manage/src/main/java/com/moral/api/service/ManageRoleService.java b/screen-manage/src/main/java/com/moral/api/service/ManageRoleService.java index a04c024..7db2502 100644 --- a/screen-manage/src/main/java/com/moral/api/service/ManageRoleService.java +++ b/screen-manage/src/main/java/com/moral/api/service/ManageRoleService.java @@ -30,4 +30,6 @@ @Transactional Map<String,Object> deleteManageRole(Map map); + + ManageRole getRoleByAccountId(Integer accountId); } diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/ManageAccountRoleServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/ManageAccountRoleServiceImpl.java index cceb0f7..f521ccb 100644 --- a/screen-manage/src/main/java/com/moral/api/service/impl/ManageAccountRoleServiceImpl.java +++ b/screen-manage/src/main/java/com/moral/api/service/impl/ManageAccountRoleServiceImpl.java @@ -2,18 +2,30 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; +import com.moral.api.entity.ManageAccount; import com.moral.api.entity.ManageAccountRole; +import com.moral.api.entity.ManageRole; +import com.moral.api.mapper.ManageAccountMapper; import com.moral.api.mapper.ManageAccountRoleMapper; +import com.moral.api.mapper.ManageRoleMapper; import com.moral.api.pojo.dto.accountRole.AccountRoleDTO; import com.moral.api.pojo.form.accountRole.AccountRoleUpdateForm; import com.moral.api.service.ManageAccountRoleService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.moral.api.service.ManageAccountService; +import com.moral.api.service.ManageRoleService; +import com.moral.api.util.LogUtils; import com.moral.constant.Constants; import com.moral.constant.ResponseCodeEnum; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.ObjectUtils; +import org.springframework.web.context.request.RequestContextHolder; +import org.springframework.web.context.request.ServletRequestAttributes; + +import javax.management.relation.Role; +import javax.servlet.http.HttpServletRequest; /** * <p> @@ -28,6 +40,14 @@ @Autowired ManageAccountRoleMapper manageAccountRoleMapper; + @Autowired + ManageRoleMapper manageRoleMapper; + @Autowired + ManageRoleService manageRoleService; + @Autowired + ManageAccountMapper manageAccountMapper; + @Autowired + LogUtils logUtils; @Override @Transactional @@ -37,21 +57,55 @@ //������ Integer accountId = form.getAccountId(); Integer roleId = form.getRoleId(); + //������������������������������������������ + ManageAccount account = manageAccountMapper.selectById(accountId); + //������������������������������������������ + ManageRole updateRole = null; + if (!ObjectUtils.isEmpty(roleId)) { + QueryWrapper<ManageRole> queryWrapper = new QueryWrapper(); + queryWrapper.eq("is_delete", Constants.NOT_DELETE); + queryWrapper.eq("id", roleId); + updateRole = manageRoleMapper.selectOne(queryWrapper); + } + //������������������������������������ + ManageRole oldRole = manageRoleService.getRoleByAccountId(accountId); //������������������������������������ UpdateWrapper updateWrapper = new UpdateWrapper(); updateWrapper.set("is_delete", Constants.DELETE); updateWrapper.eq("account_id", accountId); manageAccountRoleMapper.update(null, updateWrapper); - if(!ObjectUtils.isEmpty(roleId)){ + if (!ObjectUtils.isEmpty(roleId)) { ManageAccountRole role = new ManageAccountRole(); role.setAccountId(accountId); role.setRoleId(roleId); manageAccountRoleMapper.insert(role); } + //������������ + insertUpdateLog(oldRole,updateRole,account); //������������������ dto.setCode(ResponseCodeEnum.SUCCESS.getCode()); dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg()); return dto; } + private void insertUpdateLog(ManageRole oldRole, ManageRole updateRole, ManageAccount account) { + HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); + StringBuilder content = new StringBuilder(); + content.append("������������������").append(account.getUserName() + ";") + .append("������:" + account.getAccount() + ";") + .append("������:"); + + if(ObjectUtils.isEmpty(oldRole)) + content.append("���->"); + else + content.append(oldRole.getName()+"->"); + + if(ObjectUtils.isEmpty(updateRole)) + content.append("���;"); + else + content.append(updateRole.getName()+";"); + + logUtils.saveOperationForManage(request, content.toString(), Constants.UPDATE_OPERATE_TYPE); + } + } diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java index 6f2cb80..4877afb 100644 --- a/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java +++ b/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java @@ -12,6 +12,7 @@ import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; +import org.springframework.util.ObjectUtils; import org.springframework.util.StringUtils; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes; @@ -237,6 +238,21 @@ return resultMap; } + @Override + public ManageRole getRoleByAccountId(Integer accountId) { + QueryWrapper<ManageAccountRole> queryAccountRoleWrapper = new QueryWrapper<>(); + queryAccountRoleWrapper.eq("is_delete",Constants.NOT_DELETE); + queryAccountRoleWrapper.eq("account_id",accountId); + ManageAccountRole accountRole = manageAccountRoleMapper.selectOne(queryAccountRoleWrapper); + if(ObjectUtils.isEmpty(accountRole)) + return null; + Integer roleId = accountRole.getRoleId(); + QueryWrapper<ManageRole> queryRoleWrapper = new QueryWrapper(); + queryRoleWrapper.eq("is_delete", Constants.NOT_DELETE); + queryRoleWrapper.eq("id", roleId); + return manageRoleMapper.selectOne(queryRoleWrapper); + } + /** * @Description: ��������������� * @Param: [list, menuId]list���menuId������ -- Gitblit v1.8.0