UserController.java 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  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.UserDTO;
  5. import com.izouma.nineth.dto.UserRegister;
  6. import com.izouma.nineth.enums.AuthorityName;
  7. import com.izouma.nineth.exception.BusinessException;
  8. import com.izouma.nineth.repo.UserRepo;
  9. import com.izouma.nineth.security.Authority;
  10. import com.izouma.nineth.security.JwtTokenUtil;
  11. import com.izouma.nineth.security.JwtUserFactory;
  12. import com.izouma.nineth.service.FollowService;
  13. import com.izouma.nineth.service.UserService;
  14. import com.izouma.nineth.utils.ObjUtils;
  15. import com.izouma.nineth.utils.SecurityUtils;
  16. import com.izouma.nineth.utils.excel.ExcelUtils;
  17. import io.swagger.annotations.ApiOperation;
  18. import lombok.AllArgsConstructor;
  19. import org.springframework.data.domain.Page;
  20. import org.springframework.security.access.prepost.PreAuthorize;
  21. import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
  22. import org.springframework.web.bind.annotation.*;
  23. import javax.servlet.http.HttpServletResponse;
  24. import java.io.IOException;
  25. import java.util.Collections;
  26. import java.util.List;
  27. @AllArgsConstructor
  28. @RestController
  29. @RequestMapping("/user")
  30. public class UserController extends BaseController {
  31. private UserRepo userRepo;
  32. private UserService userService;
  33. private JwtTokenUtil jwtTokenUtil;
  34. private FollowService followService;
  35. @PostMapping("/register")
  36. public User register(@RequestParam String username,
  37. @RequestParam String password) {
  38. UserRegister user = UserRegister.builder()
  39. .username(username)
  40. .nickname(username)
  41. .password(new BCryptPasswordEncoder().encode(password))
  42. .authorities(Collections.singleton(Authority.get(AuthorityName.ROLE_USER)))
  43. .build();
  44. return userService.create(user);
  45. }
  46. @PreAuthorize("hasRole('ADMIN')")
  47. @PostMapping("/create")
  48. public User create(@RequestBody UserRegister userRegister) {
  49. return userService.create(userRegister);
  50. }
  51. @PostMapping("/save")
  52. public User save(@RequestBody User user) {
  53. if (user.getId() != null) {
  54. return userService.update(user);
  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<UserDTO> all(@RequestBody PageQuery pageQuery) {
  72. if (!SecurityUtils.hasRole(AuthorityName.ROLE_ADMIN)) {
  73. pageQuery.getQuery().put("hasRole", "ROLE_MINTER");
  74. }
  75. return userService.toDTO(userService.all(pageQuery));
  76. }
  77. // @PreAuthorize("hasRole('ADMIN')")
  78. @GetMapping("/get/{id}")
  79. public UserDTO get(@PathVariable Long id) {
  80. return userService.toDTO(userRepo.findById(id).orElseThrow(new BusinessException("无记录")), true);
  81. }
  82. @PreAuthorize("hasRole('ADMIN')")
  83. @PostMapping("/del/{id}")
  84. public void del(@PathVariable Long id) {
  85. userService.del(id);
  86. }
  87. @GetMapping("/excel")
  88. @ResponseBody
  89. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  90. List<User> data = userService.all(pageQuery).getContent();
  91. ExcelUtils.export(response, data);
  92. }
  93. @PostMapping("/getMaUserInfo")
  94. @ApiOperation(value = "获取小程序用户信息")
  95. public User getMaUserInfo(String sessionKey, String rawData, String signature, String encryptedData, String iv) {
  96. User user = userService.getMaUserInfo(sessionKey, rawData, signature, encryptedData, iv);
  97. if (user != null) {
  98. return user;
  99. }
  100. throw new BusinessException("获取用户信息失败");
  101. }
  102. @PreAuthorize("hasRole('ADMIN')")
  103. @PostMapping("/setPasswordAdmin")
  104. public String setPasswordAdmin(@RequestParam Long userId, @RequestParam String password) {
  105. return userService.setPassword(userId, password);
  106. }
  107. @PostMapping("/changePassword")
  108. public String changePassword(@RequestParam String password, @RequestParam String code) {
  109. return userService.setPassword(SecurityUtils.getAuthenticatedUser().getId(), code, password);
  110. }
  111. @PostMapping("/forgotPassword")
  112. @ApiOperation("忘记密码")
  113. public String forgotPassword(@RequestParam String phone, @RequestParam String password, @RequestParam String code) {
  114. return userService.forgotPassword(phone, password, code);
  115. }
  116. @PreAuthorize("hasRole('ADMIN')")
  117. @GetMapping("/getToken/{userId}")
  118. public String getToken(@PathVariable Long userId) {
  119. return jwtTokenUtil.generateToken(JwtUserFactory.create(userRepo.findById(userId)
  120. .orElseThrow(new BusinessException("用户不存在"))));
  121. }
  122. @PostMapping("/bindPhone")
  123. public void bindPhone(@RequestParam String phone) {
  124. userService.bindPhone(SecurityUtils.getAuthenticatedUser().getId(), phone);
  125. }
  126. @GetMapping("/{id}/follow")
  127. public void follow(@PathVariable Long id) {
  128. followService.follow(SecurityUtils.getAuthenticatedUser().getId(), id);
  129. }
  130. @GetMapping("/{id}/unfollow")
  131. public void unfollow(@PathVariable Long id) {
  132. followService.unfollow(SecurityUtils.getAuthenticatedUser().getId(), id);
  133. }
  134. @GetMapping("/myFollows")
  135. @ApiOperation("我的关注")
  136. public List<UserDTO> myFollows() {
  137. return userService.toDTO(userRepo.userFollows(SecurityUtils.getAuthenticatedUser().getId()));
  138. }
  139. @GetMapping("/myFollowers")
  140. @ApiOperation("关注我的")
  141. public List<UserDTO> myFollowers() {
  142. return userService.toDTO(userRepo.userFollowers(SecurityUtils.getAuthenticatedUser().getId()));
  143. }
  144. @PostMapping("/setTradeCode")
  145. public void setTradeCode(@RequestParam String code, @RequestParam String tradeCode) {
  146. userService.setTradeCode(SecurityUtils.getAuthenticatedUser().getId(), code, tradeCode);
  147. }
  148. @PostMapping("/verifyTradeCode")
  149. public void verifyTradeCode(@RequestParam String tradeCode) {
  150. userService.verifyTradeCode(SecurityUtils.getAuthenticatedUser().getId(), tradeCode);
  151. }
  152. }