UserController.java 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.User;
  3. import com.izouma.nineth.dto.PageQuery;
  4. import com.izouma.nineth.dto.UserRegister;
  5. import com.izouma.nineth.enums.AuthorityName;
  6. import com.izouma.nineth.exception.BusinessException;
  7. import com.izouma.nineth.repo.UserRepo;
  8. import com.izouma.nineth.security.Authority;
  9. import com.izouma.nineth.security.JwtTokenUtil;
  10. import com.izouma.nineth.security.JwtUserFactory;
  11. import com.izouma.nineth.service.UserService;
  12. import com.izouma.nineth.utils.ObjUtils;
  13. import com.izouma.nineth.utils.SecurityUtils;
  14. import com.izouma.nineth.utils.excel.ExcelUtils;
  15. import io.swagger.annotations.ApiOperation;
  16. import lombok.AllArgsConstructor;
  17. import org.springframework.data.domain.Page;
  18. import org.springframework.security.access.prepost.PreAuthorize;
  19. import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
  20. import org.springframework.web.bind.annotation.*;
  21. import javax.servlet.http.HttpServletResponse;
  22. import java.io.IOException;
  23. import java.util.Collections;
  24. import java.util.List;
  25. @AllArgsConstructor
  26. @RestController
  27. @RequestMapping("/user")
  28. public class UserController extends BaseController {
  29. private UserRepo userRepo;
  30. private UserService userService;
  31. private JwtTokenUtil jwtTokenUtil;
  32. @PostMapping("/register")
  33. public User register(@RequestParam String username,
  34. @RequestParam String password) {
  35. UserRegister user = UserRegister.builder()
  36. .username(username)
  37. .nickname(username)
  38. .password(new BCryptPasswordEncoder().encode(password))
  39. .authorities(Collections.singleton(Authority.get(AuthorityName.ROLE_USER)))
  40. .build();
  41. return userService.create(user);
  42. }
  43. @PreAuthorize("hasRole('ADMIN')")
  44. @PostMapping("/create")
  45. public User create(@RequestBody UserRegister userRegister) {
  46. return userService.create(userRegister);
  47. }
  48. @PreAuthorize("hasRole('ADMIN')")
  49. @PostMapping("/save")
  50. public User save(@RequestBody User user) {
  51. if (user.getId() != null) {
  52. User orig = userRepo.findById(user.getId()).orElseThrow(new BusinessException("无记录"));
  53. ObjUtils.merge(orig, user);
  54. return userRepo.save(orig);
  55. }
  56. return userRepo.save(user);
  57. }
  58. @GetMapping("/my")
  59. public User my() {
  60. return userRepo.findById(SecurityUtils.getAuthenticatedUser().getId())
  61. .orElseThrow(new BusinessException("用户不存在"));
  62. }
  63. @GetMapping("/myAdmin")
  64. @PreAuthorize("hasRole('ADMIN')")
  65. public User myAdmin() {
  66. return userRepo.findById(SecurityUtils.getAuthenticatedUser().getId())
  67. .orElseThrow(new BusinessException("用户不存在"));
  68. }
  69. @PreAuthorize("hasRole('ADMIN')")
  70. @PostMapping("/all")
  71. public Page<User> all(@RequestBody PageQuery pageQuery) {
  72. return userService.all(pageQuery);
  73. }
  74. @PreAuthorize("hasRole('ADMIN')")
  75. @GetMapping("/get/{id}")
  76. public User get(@PathVariable Long id) {
  77. return userRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  78. }
  79. @PreAuthorize("hasRole('ADMIN')")
  80. @PostMapping("/del/{id}")
  81. public void del(@PathVariable Long id) {
  82. userService.del(id);
  83. }
  84. @GetMapping("/excel")
  85. @ResponseBody
  86. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  87. List<User> data = all(pageQuery).getContent();
  88. ExcelUtils.export(response, data);
  89. }
  90. @PostMapping("/getMaUserInfo")
  91. @ApiOperation(value = "获取小程序用户信息")
  92. public User getMaUserInfo(String sessionKey, String rawData, String signature, String encryptedData, String iv) {
  93. User user = userService.getMaUserInfo(sessionKey, rawData, signature, encryptedData, iv);
  94. if (user != null) {
  95. return user;
  96. }
  97. throw new BusinessException("获取用户信息失败");
  98. }
  99. @PreAuthorize("hasRole('ADMIN')")
  100. @PostMapping("/setPasswordAdmin")
  101. public String setPasswordAdmin(@RequestParam Long userId, @RequestParam String password) {
  102. return userService.setPassword(userId, password);
  103. }
  104. @PostMapping("/changePassword")
  105. public String changePassword(@RequestParam String password, @RequestParam String key, @RequestParam String code) {
  106. return userService.setPassword(SecurityUtils.getAuthenticatedUser().getId(), key, code, password);
  107. }
  108. @PreAuthorize("hasRole('ADMIN')")
  109. @GetMapping("/getToken/{userId}")
  110. public String getToken(@PathVariable Long userId) {
  111. return jwtTokenUtil.generateToken(JwtUserFactory.create(userRepo.findById(userId)
  112. .orElseThrow(new BusinessException("用户不存在"))));
  113. }
  114. @PostMapping("/bindPhone")
  115. public void bindPhone(@RequestParam String phone) {
  116. userService.bindPhone(SecurityUtils.getAuthenticatedUser().getId(), phone);
  117. }
  118. }