package com.sandu.ximon.admin.service; import cn.hutool.core.collection.CollectionUtil; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.github.pagehelper.PageHelper; import com.sandu.common.enums.RoleLevelStatus; import com.sandu.common.execption.BusinessException; import com.sandu.common.object.BaseConditionVO; import com.sandu.common.service.impl.BaseServiceImpl; import com.sandu.common.util.SpringContextHolder; import com.sandu.ximon.admin.param.AdminParam; import com.sandu.ximon.admin.param.PwdParam; import com.sandu.ximon.admin.param.UserPwsParm; import com.sandu.ximon.admin.security.SecurityUtils; import com.sandu.ximon.admin.security.authcode.MD5Util; import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils; import com.sandu.ximon.dao.bo.AdminBo; import com.sandu.ximon.dao.bo.MenuNode; import com.sandu.ximon.dao.domain.*; import com.sandu.ximon.dao.enums.AdministratorEnums; import com.sandu.ximon.dao.enums.OrderByEnums; import com.sandu.ximon.dao.mapper.AdminMapper; import lombok.AllArgsConstructor; import org.springframework.security.crypto.password.PasswordEncoder; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; /** * @author chenjiantian * @date 2021/11/24 11:02 */ @Service @AllArgsConstructor public class AdminService extends BaseServiceImpl { private final PasswordEncoder passwordEncoder; private final AdminRoleRelationService adminRoleRelationService; private final RoleService roleService; private AdminMapper adminMapper; public Admin findByUserName(String username) { return getOne(Wrappers.lambdaQuery(Admin.class).eq(Admin::getUsername, username).last("limit 1")); } @Transactional(rollbackFor = Exception.class) public boolean register(AdminParam param) { Admin admin = findByUserName(param.getUsername()); if (admin != null) { throw new BusinessException("当前账号" + param.getUsername() + "已经存在"); } Admin save = new Admin(); save.setUsername(param.getUsername()); save.setPassword(passwordEncoder.encode(param.getPassword())); save.setNickName(param.getNickName()); save.setMobile(param.getMobile()); save.setNote(param.getNote()); if (!save(save)) { throw new BusinessException("注册管理员失败"); } Role role = roleService.getById(param.getRoleId()); if (role == null) { throw new BusinessException("角色不存在"); } if (RoleLevelStatus.SUPER.getCode().equals(role.getLevel())) { throw new BusinessException("无法添加超级管理员"); } AdminRoleRelation adminRoleRelation = new AdminRoleRelation(); adminRoleRelation.setAdminId(save.getId()); adminRoleRelation.setRoleId(param.getRoleId()); if (!adminRoleRelationService.save(adminRoleRelation)) { throw new BusinessException("添加管理员角色失败"); } /** * 添加管理员日志记录开始 */ String content = "新注册管理员:" + param.getUsername(); StoreOperationRecordsUtils.storeOperationData(null, null, "添加管理员", content); /** * 添加管理员日志记录结束 */ return true; } @Transactional(rollbackFor = Exception.class) public boolean updateAdmin(Long adminId, AdminParam param) { Admin admin = getById(adminId); if (admin == null) { throw new BusinessException("找不到管理员"); } List roles = roleService.listByAdminId(admin.getId()); if (CollectionUtil.isEmpty(roles)) { throw new BusinessException("当前用户没有角色"); } List levels = roles.stream().map(Role::getLevel).collect(Collectors.toList()); int min = Collections.min(levels); roleService.assertLevels(min); Admin update = new Admin(); update.setId(adminId); update.setPassword(passwordEncoder.encode(param.getPassword())); update.setNickName(param.getNickName()); update.setMobile(param.getMobile()); update.setNote(param.getNote()); if (!updateById(update)) { throw new BusinessException("编辑管理员失败"); } adminRoleRelationService.remove(Wrappers.lambdaQuery(AdminRoleRelation.class).eq(AdminRoleRelation::getAdminId, admin.getId())); AdminRoleRelation adminRoleRelation = new AdminRoleRelation(); adminRoleRelation.setAdminId(adminId); adminRoleRelation.setRoleId(param.getRoleId()); if (!adminRoleRelationService.save(adminRoleRelation)) { throw new BusinessException("添加管理员角色失败"); } return true; } /** * 修改当前登录用户密码 * * @param param * @return */ public boolean updateMyPassword(PwdParam param) { Long userId = SecurityUtils.getUserId(); Admin admin = getById(userId); if (admin == null) { throw new BusinessException("用户不存在"); } //判断旧密码与数据库是否一致 if (passwordEncoder.matches(param.getOldPass(), admin.getPassword())) { //加密新密码 admin.setId(userId); admin.setPassword(passwordEncoder.encode(param.getNewPass())); return updateById(admin); } else { throw new BusinessException("旧密码不正确,请重新确认密码!"); } } /** * 修改管理员的密码 * * @param param * @return */ public boolean updateAdminPassword(UserPwsParm param) { Admin admin = getOne(Wrappers.lambdaQuery(Admin.class).eq(Admin::getId, param.getUserid())); if (admin == null) { throw new BusinessException("用户不存在"); } //加密新密码 admin.setPassword(passwordEncoder.encode(param.getNewPass())); return updateById(admin); } @Transactional(rollbackFor = Exception.class) public boolean deleteAdmin(Long adminId) { boolean flag = false; Admin admin = getById(adminId); if (admin == null) { throw new BusinessException("找不到管理员"); } if (!AdministratorEnums.ADMIN.getCode().equals(SecurityUtils.getUserDetails().getAdministratorType())) { throw new BusinessException("只有超级管理员才能删除用户"); } //管理员角色关系表 AdminRoleRelationService adminRoleRelationService = SpringContextHolder.getBean(AdminRoleRelationService.class); //有用户必定有用户与角色的关系数据 AdminRoleRelation one = adminRoleRelationService.getOne(Wrappers.lambdaQuery(AdminRoleRelation.class).eq(AdminRoleRelation::getAdminId, admin.getId())); Role role = SpringContextHolder.getBean(RoleService.class).getOne(Wrappers.lambdaQuery(Role.class).eq(Role::getId, one.getRoleId())); if (role == null) { throw new BusinessException("数据异常!"); } if (role.getLevel().equals(RoleLevelStatus.SUPER.getCode())) { throw new BusinessException("超级管理员无法删除"); } else { //删用户 if (removeById(adminId)) { //删角色关系表信息 flag = adminRoleRelationService.removeById(one); //删除失败回滚数据 if (!flag) { throw new BusinessException("删除管理员用户失败!"); } } } /** * 删除管理员 日志记录开始 */ String content = "删除管理员:" + admin.getUsername() + "用户id:" + admin; StoreOperationRecordsUtils.storeOperationData(null, null, "删除管理员", content); /** * 删除管理员 日志记录结束 */ return flag; } /** * 修改超级管理员、管理员用户头像 * * @param userId * @param IconUrl * @return */ public boolean updateIcon(Long userId, String IconUrl) { Admin one = getOne(Wrappers.lambdaQuery(Admin.class).eq(Admin::getId, userId)); if (one == null) { throw new BusinessException("用户不存在"); } one.setIcon(IconUrl); return updateById(one); } public List listAdmin(BaseConditionVO baseConditionVO, String keyword, Integer order, Integer seq) { //排序字段 String orderByResult = OrderByEnums.ADMIN_ID.getCode(); //正序、倒叙 String orderBySeq = OrderByEnums.ASC.getCode(); if (order != null) { switch (order) { case 1: orderByResult = OrderByEnums.ADMIN_ID.getCode(); break; case 2: orderByResult = OrderByEnums.ADMIN_CREATE_TIME.getCode(); break; case 3: orderByResult = OrderByEnums.ADMIN_LOGIN_TIME.getCode(); break; default: } } if (seq != null) { switch (seq) { case 1: orderBySeq = OrderByEnums.ASC.getCode(); break; case 2: orderBySeq = OrderByEnums.DESC.getCode(); break; default: break; } } //排序方式 String orderBy = orderByResult + " " + orderBySeq; if (baseConditionVO != null) { PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize(), orderBy); } return adminMapper.listAdmin(keyword); } /** * 获取用户权限列表地 */ public List getUserPermissionList() { List resultList; //通过用户UserID获取用户角色 AdminRoleRelation one = SpringContextHolder.getBean(AdminRoleRelationService.class). getOne(Wrappers.lambdaQuery(AdminRoleRelation.class).eq(AdminRoleRelation::getAdminId, SecurityUtils.getUserId())); //判空 if (one == null) { throw new BusinessException("该用户未绑定角色"); } //通过RoleID获取MeunId列表 List menuIdList = SpringContextHolder.getBean(RoleMenuRelationService.class) .list(Wrappers.lambdaQuery(RoleMenuRelation.class).eq(RoleMenuRelation::getRoleId, one.getRoleId())); //判空 if (menuIdList.isEmpty()) { return new ArrayList<>(); } List menuIds = new ArrayList<>(menuIdList.size()); for (RoleMenuRelation bean : menuIdList) { menuIds.add(bean.getMenuId()); } resultList = SpringContextHolder.getBean(MenuService.class).getUserPermissionListById(menuIds); return resultList; } /** * 生成key * * @param userId * @return */ public String creatUserKey(Long userId, Integer type) { if (userId == null) { throw new BusinessException("用户ID不能为空!"); } //0:充重置key,1:获取key if (type == null || (type != 0 && type != 1)) { type = 1; } ClientService clientService = SpringContextHolder.getBean(ClientService.class); Client client = clientService.getOne(Wrappers.lambdaQuery(Client.class).eq(Client::getId, userId)); if (client == null) { throw new BusinessException("用户不存在,请重新确认!"); } /** * key操作日志 */ String content = "操作用户key:" + SecurityUtils.getUsername() + " 被操作用户id:" + userId; //获取 if (type == 1) { content += "操作类型:获取key"; StoreOperationRecordsUtils.storeOperationData(null, null, "操作用户key", content); return "用户的便捷登录key为:" + client.getUserKey(); } else { //更新 String md5 = MD5Util.md5("uesrId:" + userId + "_AdministratorType:" + 2 + "time:" + System.currentTimeMillis()); client.setUserKey(md5); boolean flag = clientService.updateById(client); if (flag) { content += "操作类型:生成key,新的key为:" + md5; StoreOperationRecordsUtils.storeOperationData(null, null, "操作用户key", content); return "生成便捷登录key成功,该用户key为:" + md5 + ",请妥善保管!"; } else { throw new BusinessException("生成便捷登录key失败!"); } } } }