UserController.java 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. package com.izouma.nineth.web;
  2. import com.huifu.adapay.core.exception.BaseAdaPayException;
  3. import com.izouma.nineth.domain.User;
  4. import com.izouma.nineth.dto.*;
  5. import com.izouma.nineth.enums.AuthorityName;
  6. import com.izouma.nineth.exception.BusinessException;
  7. import com.izouma.nineth.repo.UserBankCardRepo;
  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.SecurityUtils;
  15. import com.izouma.nineth.utils.excel.ExcelUtils;
  16. import io.swagger.annotations.ApiOperation;
  17. import lombok.AllArgsConstructor;
  18. import me.chanjar.weixin.common.error.WxErrorException;
  19. import org.apache.commons.lang3.StringUtils;
  20. import org.springframework.data.domain.Page;
  21. import org.springframework.security.access.prepost.PreAuthorize;
  22. import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
  23. import org.springframework.web.bind.annotation.*;
  24. import javax.servlet.http.HttpServletResponse;
  25. import java.io.IOException;
  26. import java.util.Collections;
  27. import java.util.HashMap;
  28. import java.util.List;
  29. import java.util.Map;
  30. @AllArgsConstructor
  31. @RestController
  32. @RequestMapping("/user")
  33. public class UserController extends BaseController {
  34. private UserRepo userRepo;
  35. private UserService userService;
  36. private JwtTokenUtil jwtTokenUtil;
  37. private FollowService followService;
  38. private UserBankCardRepo userBankCardRepo;
  39. @PostMapping("/register")
  40. public User register(@RequestParam String username,
  41. @RequestParam String password) {
  42. UserRegister user = UserRegister.builder()
  43. .username(username)
  44. .nickname(username)
  45. .password(new BCryptPasswordEncoder().encode(password))
  46. .authorities(Collections.singleton(Authority.get(AuthorityName.ROLE_USER)))
  47. .build();
  48. return userService.create(user);
  49. }
  50. @PreAuthorize("hasRole('ADMIN')")
  51. @PostMapping("/create")
  52. public User create(@RequestBody UserRegister userRegister) {
  53. return userService.create(userRegister);
  54. }
  55. @PostMapping("/save")
  56. public User save(@RequestBody User user) {
  57. if (user.getId() != null) {
  58. return userService.update(user);
  59. }
  60. return userRepo.save(user);
  61. }
  62. @GetMapping("/my")
  63. public User my() {
  64. return userRepo.findById(SecurityUtils.getAuthenticatedUser().getId())
  65. .orElseThrow(new BusinessException("用户不存在"));
  66. }
  67. @GetMapping("/myAdmin")
  68. @PreAuthorize("hasRole('ADMIN')")
  69. public User myAdmin() {
  70. return userRepo.findById(SecurityUtils.getAuthenticatedUser().getId())
  71. .orElseThrow(new BusinessException("用户不存在"));
  72. }
  73. // @PreAuthorize("hasRole('ADMIN')")
  74. @PostMapping("/all")
  75. public Page<UserDTO> all(@RequestBody PageQuery pageQuery) {
  76. if (!(SecurityUtils.getAuthenticatedUser() != null && SecurityUtils.getAuthenticatedUser().isAdmin())) {
  77. pageQuery.getQuery().put("hasRole", "ROLE_MINTER");
  78. }
  79. return userService.toDTO(userService.all(pageQuery));
  80. }
  81. // @PreAuthorize("hasRole('ADMIN')")
  82. @GetMapping("/get/{id}")
  83. public UserDTO get(@PathVariable Long id) {
  84. return userService.toDTO(userRepo.findById(id).orElseThrow(new BusinessException("无记录")), true);
  85. }
  86. @PreAuthorize("hasRole('ADMIN')")
  87. @PostMapping("/del/{id}")
  88. public void del(@PathVariable Long id) {
  89. userService.del(id);
  90. }
  91. @GetMapping("/excel")
  92. @ResponseBody
  93. public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
  94. List<User> data = userService.all(pageQuery).getContent();
  95. ExcelUtils.export(response, data);
  96. }
  97. @PostMapping("/getMaUserInfo")
  98. @ApiOperation(value = "获取小程序用户信息")
  99. public User getMaUserInfo(String sessionKey, String rawData, String signature, String encryptedData, String iv) {
  100. User user = userService.getMaUserInfo(sessionKey, rawData, signature, encryptedData, iv);
  101. if (user != null) {
  102. return user;
  103. }
  104. throw new BusinessException("获取用户信息失败");
  105. }
  106. @PostMapping("/code2openId")
  107. @ApiOperation(value = "获取OpenId")
  108. public String code2openId(@RequestParam String code) throws WxErrorException {
  109. return userService.code2openId(code);
  110. }
  111. @PreAuthorize("hasRole('ADMIN')")
  112. @PostMapping("/setPasswordAdmin")
  113. public String setPasswordAdmin(@RequestParam Long userId, @RequestParam String password) {
  114. return userService.setPassword(userId, password);
  115. }
  116. @PostMapping("/changePassword")
  117. @ApiOperation("修改密码")
  118. public String changePassword(@RequestParam String password, @RequestParam String code) {
  119. return userService.setPassword(SecurityUtils.getAuthenticatedUser().getId(), code, password);
  120. }
  121. @PostMapping("/forgotPassword")
  122. @ApiOperation("忘记密码")
  123. public String forgotPassword(@RequestParam String phone, @RequestParam String password, @RequestParam String code) {
  124. return userService.forgotPassword(phone, password, code);
  125. }
  126. @PreAuthorize("hasRole('ADMIN')")
  127. @GetMapping("/getToken/{userId}")
  128. public String getToken(@PathVariable Long userId) {
  129. return jwtTokenUtil.generateToken(JwtUserFactory.create(userRepo.findById(userId)
  130. .orElseThrow(new BusinessException("用户不存在"))));
  131. }
  132. @PostMapping("/bindPhone")
  133. public void bindPhone(@RequestParam String phone) {
  134. userService.bindPhone(SecurityUtils.getAuthenticatedUser().getId(), phone);
  135. }
  136. @GetMapping("/{id}/follow")
  137. public void follow(@PathVariable Long id) {
  138. followService.follow(SecurityUtils.getAuthenticatedUser().getId(), id);
  139. }
  140. @GetMapping("/{id}/unfollow")
  141. public void unfollow(@PathVariable Long id) {
  142. followService.unfollow(SecurityUtils.getAuthenticatedUser().getId(), id);
  143. }
  144. @GetMapping("/myFollows")
  145. @ApiOperation("我的关注")
  146. public List<UserDTO> myFollows() {
  147. return userService.toDTO(userRepo.userFollows(SecurityUtils.getAuthenticatedUser().getId()));
  148. }
  149. @GetMapping("/myFollowers")
  150. @ApiOperation("关注我的")
  151. public List<UserDTO> myFollowers() {
  152. return userService.toDTO(userRepo.userFollowers(SecurityUtils.getAuthenticatedUser().getId()));
  153. }
  154. @PostMapping("/setTradeCode")
  155. @ApiOperation("修改交易密码")
  156. public void setTradeCode(@RequestParam String token, @RequestParam String tradeCode) {
  157. userService.setTradeCode(SecurityUtils.getAuthenticatedUser().getId(), token, tradeCode);
  158. }
  159. @PostMapping("/verifyTradeCode")
  160. @ApiOperation("验证交易密码")
  161. public void verifyTradeCode(@RequestParam String tradeCode) {
  162. userService.verifyTradeCode(SecurityUtils.getAuthenticatedUser().getId(), tradeCode);
  163. }
  164. @PostMapping("/searchByPhone")
  165. public Map<String, Object> searchByPhone(@RequestParam String phone) {
  166. return userService.searchByPhone(phone);
  167. }
  168. @PreAuthorize("hasAnyRole('ADMIN', 'OPERATOR')")
  169. @PostMapping("/searchByPhoneAdmin")
  170. public Map<String, Object> searchByPhoneAdmin(@RequestParam String phone) {
  171. return userService.searchByPhoneAdmin(phone);
  172. }
  173. @GetMapping("/tradeCodeStatus")
  174. public Object tradeCodeStatus() {
  175. return new HashMap<String, Object>() {{
  176. put("set", StringUtils.isNotBlank(
  177. userRepo.findById(SecurityUtils.getAuthenticatedUser().getId()).map(User::getTradeCode).orElse(null)
  178. ));
  179. }};
  180. }
  181. @GetMapping("/myBankCard")
  182. public List<UserBankCard> myBankCard() {
  183. return userBankCardRepo.findByUserId(SecurityUtils.getAuthenticatedUser().getId());
  184. }
  185. @PostMapping("/addBankCard")
  186. public void addBankCard(@RequestParam String bankNo, @RequestParam String phone, @RequestParam String code) throws BaseAdaPayException {
  187. userService.addBankCard(SecurityUtils.getAuthenticatedUser().getId(), bankNo, phone, code);
  188. }
  189. @PostMapping("/removeBankCard")
  190. public void removeBankCard() throws BaseAdaPayException {
  191. userService.removeBankCard(SecurityUtils.getAuthenticatedUser().getId());
  192. }
  193. @PreAuthorize("hasAnyRole('ADMIN')")
  194. @PostMapping("/batchRegister")
  195. public Map<String, Object> batchRegister(@RequestParam String phones, @RequestParam String defaultPassword) {
  196. return userService.batchRegister(phones, defaultPassword);
  197. }
  198. @PreAuthorize("hasAnyRole('ADMIN')")
  199. @PostMapping("/exportInvite")
  200. @ResponseBody
  201. public void exportInvite(HttpServletResponse response, @RequestBody PageQuery pageQuery) throws IOException {
  202. List<InvitePhoneDTO> data = userService.all(pageQuery)
  203. .map(InvitePhoneDTO::new)
  204. .getContent();
  205. ExcelUtils.export(response, data);
  206. }
  207. @PreAuthorize("hasAnyRole('ADMIN')")
  208. @GetMapping("/switchAccount")
  209. public String switchAccount() {
  210. userService.switchAccount();
  211. return "ok";
  212. }
  213. }