| package com.hollywood.manage.authority.service.impl; | 
|   | 
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
| import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; | 
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; | 
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
| import com.hollywood.common.basic.Constant; | 
| import com.hollywood.manage.authority.dto.SecUserDTO; | 
| import com.hollywood.manage.authority.dto.SecUsersDTO; | 
| import com.hollywood.manage.authority.mapper.SecResourcesMapper; | 
| import com.hollywood.manage.authority.mapper.SecRoleMapper; | 
| import com.hollywood.manage.authority.mapper.SecUserRoleMapper; | 
| import com.hollywood.manage.authority.model.SecResources; | 
| import com.hollywood.manage.authority.model.SecRole; | 
| import com.hollywood.manage.authority.model.SecUser; | 
| import com.hollywood.manage.authority.model.SecUserRole; | 
| import com.hollywood.manage.authority.query.SecUserLowerQuery; | 
| import com.hollywood.manage.authority.service.SecUserService; | 
| import com.hollywood.manage.authority.vo.SecResourceVO; | 
| import com.hollywood.manage.authority.vo.SecUsersVO; | 
| import com.hollywood.common.basic.PageInfo; | 
| import com.hollywood.common.exception.ServiceException; | 
| import com.hollywood.common.utils.SpringUtils; | 
| import com.hollywood.manage.authority.mapper.SecUserMapper; | 
| import org.apache.commons.compress.utils.Lists; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.security.crypto.password.PasswordEncoder; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.util.StringUtils; | 
|   | 
| import java.time.LocalDateTime; | 
| import java.util.*; | 
| import java.util.stream.Collectors; | 
|   | 
| import static java.util.Comparator.comparing; | 
| import static java.util.stream.Collectors.toList; | 
|   | 
| /** | 
|  * <p> | 
|  * 服务实现类 | 
|  * </p> | 
|  * | 
|  * @author xiaochen | 
|  * @since 2022-06-08 | 
|  */ | 
| @Service | 
| public class SecUserServiceImpl extends ServiceImpl<SecUserMapper, SecUser> implements SecUserService { | 
|   | 
|     @Autowired | 
|     private SecResourcesMapper secResourcesMapper; | 
|     @Autowired | 
|     private SecUserMapper secUserMapper; | 
|     @Autowired | 
|     private SecUserRoleMapper secUserRoleMapper; | 
|     @Autowired | 
|     private PasswordEncoder passwordEncoder; | 
|     @Autowired | 
|     private SecRoleMapper secRoleMapper; | 
|   | 
|     @Override | 
|     public List<SecResourceVO> selectUserResourcesTag(Long uid) { | 
|         List<SecResources> sysResources = secResourcesMapper.selectResourceByUid(uid); | 
|         List<Long> resourcesIds = sysResources.stream().map(SecResources::getId).collect(Collectors.toList()); | 
|         // 排序会导致结构问题 | 
|         List<SecResources> allResources = secResourcesMapper.selectList(Wrappers.lambdaQuery(SecResources.class)); | 
|         SecResourceVO item; | 
|         //获取根节点的集合 | 
|         List<SecResourceVO> root = new ArrayList<>(); | 
|         Map<Long, SecResourceVO> tempMap = new HashMap<>(3); | 
|         //子节点集合 | 
|         SecResourceVO parent; | 
|         for (SecResources resources : allResources) { | 
|             item = SpringUtils.beanCopy(resources, SecResourceVO.class); | 
|             if (resourcesIds.contains(resources.getId())) { | 
|                 item.setFlag(true); | 
|             } else { | 
|                 item.setFlag(false); | 
|             } | 
|             //每次循环都将集合重新循环添加到父集合中 | 
|             tempMap.put(resources.getId(), item); | 
|             parent = tempMap.get(resources.getParentId()); | 
|             if (Objects.nonNull(parent)) { | 
|                 //父集合不为空时,获取下级集合,追加子集合 | 
|                 parent.getChildren().add(item); | 
|                 // 对子集排序,升序 | 
|                 parent.getChildren().sort(comparing(SecResourceVO::getSort)); | 
|             } else { | 
|                 //根集合 | 
|                 root.add(item); | 
|                 // 对根排序,升序 | 
|                 root.sort(comparing(SecResourceVO::getSort)); | 
|             } | 
|         } | 
|         return root; | 
|     } | 
|   | 
|     @Override | 
|     public List<SecResourceVO> getResourceTag(Long uid) { | 
|         List<SecResources> sysResources = secResourcesMapper.selectResourceByUid(uid); | 
|         // 判空 | 
|         if (CollectionUtils.isEmpty(sysResources)) | 
|             return Lists.newArrayList(); | 
|   | 
|         // 找出所有父级 | 
|         List<SecResources> parent = sysResources.stream().filter(resources -> resources.getParentId()==0).collect(Collectors.toList()); | 
|         List<SecResourceVO> parentList = new ArrayList<>(); | 
|         for (SecResources secResources : parent) { | 
|             SecResourceVO secResourceVO = SpringUtils.beanCopy(secResources, SecResourceVO.class); | 
|             parentList.add(secResourceVO); | 
|         } | 
|         // 通过父级递归子集 | 
|         getChildren(sysResources, parentList); | 
|         return parentList; | 
|     } | 
|   | 
|     private void getChildren(List<SecResources> sysResources, List<SecResourceVO> parentList) { | 
|         parentList.forEach(parent -> { | 
|             List<SecResources> childrenList = sysResources.stream().filter(resources -> resources.getParentId().equals(parent.getId())).collect(toList()); | 
|             List<SecResourceVO> childrens = new ArrayList<>(); | 
|             for (SecResources secResources : childrenList) { | 
|                 SecResourceVO secResourceVO = SpringUtils.beanCopy(secResources, SecResourceVO.class); | 
|                 childrens.add(secResourceVO); | 
|             } | 
|             parent.setChildren(childrens); | 
|             if (!org.springframework.util.CollectionUtils.isEmpty(childrenList)) | 
|                 getChildren(sysResources, childrens); | 
|         }); | 
|     } | 
|   | 
|     /** | 
|      * 后台系统用户列表 | 
|      * | 
|      * @param dto | 
|      * @return | 
|      */ | 
|     @Override | 
|     public PageInfo<SecUsersVO> getSysUserList(SecUsersDTO dto) { | 
|   | 
|         if (dto.getPageSize() > 500) { | 
|             long count = this.count(); | 
|             dto.setPageSize(Math.toIntExact(count)); | 
|         } | 
|   | 
|         PageInfo<SecUsersVO> pageInfo = new PageInfo<>(dto.getPageNum(), dto.getPageSize()); | 
|         // 查询角色 | 
|         List<SecUsersVO> sysUserListVOS = secUserMapper.getSecUserList(dto, pageInfo); | 
|         List<SecRole> secRoles = secRoleMapper.selectList(Wrappers.lambdaQuery(SecRole.class)); | 
|   | 
|         for (SecUsersVO sysUserListVO : sysUserListVOS) { | 
|             List<SecRole> roles = secRoles.stream().filter(role -> StringUtils.hasLength(sysUserListVO.getRoleId()) && sysUserListVO.getRoleId().equals(role.getId())).collect(toList()); | 
|             sysUserListVO.setSecRole(CollectionUtils.isNotEmpty(roles) ? roles.get(0) : null); | 
|         } | 
|         pageInfo.setRecords(sysUserListVOS); | 
|         // 获取列表 | 
|         return pageInfo; | 
|     } | 
|   | 
|     @Override | 
|     public void addOrUpdateUser(SecUserDTO dto) { | 
|         if (Objects.isNull(dto.getId())) { | 
|             // 检查登陆账号是否存在 | 
|             SecUser sysUser = secUserMapper.selectOne(new LambdaQueryWrapper<SecUser>() | 
|                     .eq(SecUser::getPhone, dto.getPhone())); | 
|             if (Objects.nonNull(sysUser)) { | 
|                 throw new ServiceException("该账号已存在,请勿重复注册"); | 
|             } | 
|             dto.setAccount(dto.getPhone()); | 
|             dto.setLastLoginTime(LocalDateTime.now()); | 
|             if (StringUtils.hasLength(dto.getPassword())) { | 
|                 dto.setPassword(passwordEncoder.encode(dto.getPassword())); | 
|             }else { | 
|                 dto.setPassword(passwordEncoder.encode(Constant.DEF_PASSWORD)); | 
|             } | 
|             secUserMapper.insert(dto); | 
|         } else { | 
|             if (StringUtils.hasLength(dto.getPassword())) { | 
|                 dto.setPassword(passwordEncoder.encode(dto.getPassword())); | 
|             }else { | 
|                 dto.setPassword(passwordEncoder.encode(Constant.DEF_PASSWORD)); | 
|             } | 
|             secUserMapper.updateById(dto); | 
|             // 删除之前的 | 
|             secUserRoleMapper.delete(Wrappers.lambdaQuery(SecUserRole.class).eq(SecUserRole::getUserId, dto.getId())); | 
|         } | 
|         SecUserRole sur = new SecUserRole(); | 
|         sur.setRoleId(dto.getRoleId()); | 
|         sur.setUserId(dto.getId()); | 
|         secUserRoleMapper.insert(sur); | 
|     } | 
|   | 
|     @Override | 
|     public PageInfo<SecUser> queryLower(SecUserLowerQuery query) { | 
|         PageInfo<SecUser> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); | 
|         List<SecUser> secUserList = secUserMapper.queryLower(query, pageInfo); | 
|         pageInfo.setRecords(secUserList); | 
|         return pageInfo; | 
|     } | 
|   | 
|     @Override | 
|     public void deleteById(Long uid) { | 
|         secUserMapper.removeById(uid); | 
|     } | 
|   | 
|   | 
|     @Override | 
|     public List<SecUser> getUserByRoleId(Long id) { | 
|         return secUserMapper.getUserByRoleId(id); | 
|     } | 
|   | 
| } |