UserController.java 6.3 KB

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