UserServiceImpl.java 7.6 KB
Newer Older
1 2
package me.zhengjie.modules.system.service.impl;

3 4 5
import cn.hutool.core.io.IoUtil;
import cn.hutool.poi.excel.ExcelUtil;
import cn.hutool.poi.excel.ExcelWriter;
6
import me.zhengjie.modules.monitor.service.RedisService;
7 8 9
import me.zhengjie.modules.system.domain.User;
import me.zhengjie.exception.EntityExistException;
import me.zhengjie.exception.EntityNotFoundException;
10 11
import me.zhengjie.modules.system.domain.UserAvatar;
import me.zhengjie.modules.system.repository.UserAvatarRepository;
12 13
import me.zhengjie.modules.system.repository.UserRepository;
import me.zhengjie.modules.system.service.UserService;
14
import me.zhengjie.modules.system.service.dto.RoleSmallDTO;
15
import me.zhengjie.modules.system.service.dto.UserDTO;
16
import me.zhengjie.modules.system.service.dto.UserQueryCriteria;
17
import me.zhengjie.modules.system.service.mapper.UserMapper;
18
import me.zhengjie.utils.*;
郑杰 已提交
19
import org.springframework.beans.factory.annotation.Autowired;
20
import org.springframework.beans.factory.annotation.Value;
21 22
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
郑杰 已提交
23 24 25
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
26 27
import org.springframework.web.multipart.MultipartFile;

28 29
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
30
import java.io.File;
31 32 33
import java.io.IOException;
import java.util.*;
import java.util.stream.Collectors;
郑杰 已提交
34 35

/**
36
 * @author Zheng Jie
郑杰 已提交
37 38 39 40 41 42 43 44 45 46 47 48
 * @date 2018-11-23
 */
@Service
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true, rollbackFor = Exception.class)
public class UserServiceImpl implements UserService {

    @Autowired
    private UserRepository userRepository;

    @Autowired
    private UserMapper userMapper;

49 50 51
    @Autowired
    private RedisService redisService;

52 53 54 55 56 57
    @Autowired
    private UserAvatarRepository userAvatarRepository;

    @Value("${file.avatar}")
    private String avatar;

58 59 60 61 62 63
    @Override
    public Object queryAll(UserQueryCriteria criteria, Pageable pageable) {
        Page<User> page = userRepository.findAll((root, criteriaQuery, criteriaBuilder) -> QueryHelp.getPredicate(root,criteria,criteriaBuilder),pageable);
        return PageUtil.toPage(page.map(userMapper::toDto));
    }

64 65 66 67 68 69
    @Override
    public List<UserDTO> queryAll(UserQueryCriteria criteria) {
        List<User> users = userRepository.findAll((root, criteriaQuery, criteriaBuilder) -> QueryHelp.getPredicate(root,criteria,criteriaBuilder));
        return userMapper.toDto(users);
    }

郑杰 已提交
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
    @Override
    public UserDTO findById(long id) {
        Optional<User> user = userRepository.findById(id);
        ValidationUtil.isNull(user,"User","id",id);
        return userMapper.toDto(user.get());
    }

    @Override
    @Transactional(rollbackFor = Exception.class)
    public UserDTO create(User resources) {

        if(userRepository.findByUsername(resources.getUsername())!=null){
            throw new EntityExistException(User.class,"username",resources.getUsername());
        }

        if(userRepository.findByEmail(resources.getEmail())!=null){
            throw new EntityExistException(User.class,"email",resources.getEmail());
        }

89 90
        // 默认密码 123456,此密码是加密后的字符
        resources.setPassword("e10adc3949ba59abbe56e057f20f883e");
郑杰 已提交
91 92 93 94 95 96
        return userMapper.toDto(userRepository.save(resources));
    }

    @Override
    @Transactional(rollbackFor = Exception.class)
    public void update(User resources) {
97 98 99 100 101
        Optional<User> userOptional = userRepository.findById(resources.getId());
        ValidationUtil.isNull(userOptional,"User","id",resources.getId());

        User user = userOptional.get();

郑杰 已提交
102 103 104 105 106 107 108 109 110 111 112
        User user1 = userRepository.findByUsername(user.getUsername());
        User user2 = userRepository.findByEmail(user.getEmail());

        if(user1 !=null&&!user.getId().equals(user1.getId())){
            throw new EntityExistException(User.class,"username",resources.getUsername());
        }

        if(user2!=null&&!user.getId().equals(user2.getId())){
            throw new EntityExistException(User.class,"email",resources.getEmail());
        }

113 114 115 116 117 118 119 120
        // 如果用户的角色改变了,需要手动清理下缓存
        if (!resources.getRoles().equals(user.getRoles())) {
            String key = "role::loadPermissionByUser:" + user.getUsername();
            redisService.delete(key);
            key = "role::findByUsers_Id:" + user.getId();
            redisService.delete(key);
        }

郑杰 已提交
121 122 123 124
        user.setUsername(resources.getUsername());
        user.setEmail(resources.getEmail());
        user.setEnabled(resources.getEnabled());
        user.setRoles(resources.getRoles());
125 126 127
        user.setDept(resources.getDept());
        user.setJob(resources.getJob());
        user.setPhone(resources.getPhone());
郑杰 已提交
128 129 130 131 132 133 134 135 136 137
        userRepository.save(user);
    }

    @Override
    @Transactional(rollbackFor = Exception.class)
    public void delete(Long id) {
        userRepository.deleteById(id);
    }

    @Override
138
    public UserDTO findByName(String userName) {
郑杰 已提交
139 140 141 142 143 144 145 146 147
        User user = null;
        if(ValidationUtil.isEmail(userName)){
            user = userRepository.findByEmail(userName);
        } else {
            user = userRepository.findByUsername(userName);
        }
        if (user == null) {
            throw new EntityNotFoundException(User.class, "name", userName);
        } else {
148
            return userMapper.toDto(user);
郑杰 已提交
149 150
        }
    }
151 152 153

    @Override
    @Transactional(rollbackFor = Exception.class)
154 155
    public void updatePass(String username, String pass) {
        userRepository.updatePass(username,pass,new Date());
156 157 158 159
    }

    @Override
    @Transactional(rollbackFor = Exception.class)
160 161 162 163 164 165 166 167 168 169 170 171 172 173
    public void updateAvatar(MultipartFile multipartFile) {
        User user = userRepository.findByUsername(SecurityUtils.getUsername());
        UserAvatar userAvatar = user.getUserAvatar();
        String oldPath = "";
        if(userAvatar != null){
           oldPath = userAvatar.getPath();
        }
        File file = FileUtil.upload(multipartFile, avatar);
        userAvatar = userAvatarRepository.save(new UserAvatar(userAvatar,file.getName(), file.getPath(), FileUtil.getSize(multipartFile.getSize())));
        user.setUserAvatar(userAvatar);
        userRepository.save(user);
        if(StringUtils.isNotBlank(oldPath)){
            FileUtil.del(oldPath);
        }
174 175 176 177
    }

    @Override
    @Transactional(rollbackFor = Exception.class)
178 179
    public void updateEmail(String username, String email) {
        userRepository.updateEmail(username,email);
180
    }
181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201

    @Override
    public void download(List<UserDTO> queryAll, HttpServletResponse response) {
        List<Map<String, Object>> list = new ArrayList<>();
        for (UserDTO userDTO : queryAll) {
            List roles = userDTO.getRoles().stream().map(RoleSmallDTO::getName).collect(Collectors.toList());
            Map map = new LinkedHashMap();
            map.put("用户名", userDTO.getUsername());
            map.put("头像", userDTO.getAvatar());
            map.put("邮箱", userDTO.getEmail());
            map.put("状态", userDTO.getEnabled() ? "启用" : "禁用");
            map.put("手机号码", userDTO.getPhone());
            map.put("角色", roles);
            map.put("部门", userDTO.getDept().getName());
            map.put("岗位", userDTO.getJob().getName());
            map.put("最后修改密码的时间", userDTO.getLastPasswordResetTime());
            map.put("创建日期", userDTO.getCreateTime());
            list.add(map);
        }
        FileUtil.downloadExcel(list, response);
    }
郑杰 已提交
202
}