AuthenticationController.java 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.User;
  3. import com.izouma.nineth.domain.UserAuthority;
  4. import com.izouma.nineth.enums.AuthorityName;
  5. import com.izouma.nineth.exception.AuthenticationException;
  6. import com.izouma.nineth.security.JwtTokenUtil;
  7. import com.izouma.nineth.security.JwtUserFactory;
  8. import com.izouma.nineth.service.CaptchaService;
  9. import com.izouma.nineth.service.UserAuthorityService;
  10. import com.izouma.nineth.service.UserService;
  11. import com.izouma.nineth.utils.UserAuthoritySerializer;
  12. import io.swagger.annotations.ApiOperation;
  13. import lombok.AllArgsConstructor;
  14. import lombok.extern.slf4j.Slf4j;
  15. import org.springframework.security.authentication.AuthenticationManager;
  16. import org.springframework.transaction.annotation.Transactional;
  17. import org.springframework.web.bind.annotation.GetMapping;
  18. import org.springframework.web.bind.annotation.PostMapping;
  19. import org.springframework.web.bind.annotation.RequestMapping;
  20. import org.springframework.web.bind.annotation.RestController;
  21. import java.util.HashMap;
  22. import java.util.Map;
  23. @Slf4j
  24. @AllArgsConstructor
  25. @RestController
  26. @RequestMapping("/auth")
  27. public class AuthenticationController {
  28. private final AuthenticationManager authenticationManager;
  29. private final JwtTokenUtil jwtTokenUtil;
  30. private final UserService userService;
  31. private final CaptchaService captchaService;
  32. private final UserAuthorityService userAuthorityService;
  33. @PostMapping("/login")
  34. public String loginByUserPwd(String username, String password, Integer expiration) {
  35. User user = userService.loginByUsernamePwd(username, password);
  36. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  37. }
  38. @PostMapping("/loginAdmin")
  39. public String loginByUserPwdAdmin(String username, String password, Integer expiration) {
  40. User user = userService.loginByUsernamePwd(username, password);
  41. if (user.getAuthorities() == null ||
  42. user.getAuthorities().stream().anyMatch(au -> au.getName().equals(AuthorityName.ROLE_ADMIN.name()))) {
  43. throw new AuthenticationException("禁止登录", null);
  44. }
  45. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  46. }
  47. @PostMapping("/phoneLogin")
  48. @ApiOperation(value = "手机号验证码登录")
  49. public String phoneLogin(String phone, String code) {
  50. User user = userService.loginByPhone(phone, code);
  51. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  52. }
  53. @PostMapping("/phonePwdLogin")
  54. @ApiOperation(value = "手机号密码登录")
  55. public String phonePwdLogin(String phone, String password) {
  56. User user = userService.loginByPhonePwd(phone, password);
  57. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  58. }
  59. @PostMapping("/phoneRegister")
  60. @ApiOperation(value = "手机号密码注册")
  61. @Transactional
  62. public String phonePwdLogin(String phone, String code, String password, String inviteCode, Long invitor,
  63. Long collectionId, String captcha, String captchaKey) {
  64. // boolean verify = captchaService.verify(captchaKey, captcha);
  65. // if (!verify) {
  66. // throw new BusinessException("验证码错误");
  67. // }
  68. User user = userService.phoneRegister(phone, code, password, inviteCode, invitor, collectionId);
  69. String s = jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  70. if (user.getId() != null){
  71. UserAuthority userAuthority = new UserAuthority();
  72. userAuthority.setUserId(user.getId());
  73. userAuthority.setAuthorityName(AuthorityName.ROLE_USER);
  74. userAuthorityService.save(userAuthority);
  75. }
  76. return s;
  77. }
  78. @PostMapping("/mqPhoneRegister")
  79. @ApiOperation(value = "手机号密码注册")
  80. public String mqPhoneRegister(String phone, String code, String password, String inviteCode, Long invitor,
  81. Long collectionId, String captcha, String captchaKey) {
  82. // boolean verify = captchaService.verify(captchaKey, captcha);
  83. // if (!verify) {
  84. // throw new BusinessException("验证码错误");
  85. // }
  86. return userService.mqRegister(phone, code, password, inviteCode, invitor, collectionId);
  87. }
  88. @GetMapping("/registerResult")
  89. public Object registerResult(String phone) {
  90. Object res = userService.getRegisterResult(phone);
  91. Map<String, Object> map = new HashMap<>();
  92. if (res == null) {
  93. map.put("status", "pending");
  94. return map;
  95. } else {
  96. return res;
  97. }
  98. }
  99. @PostMapping("/testphoneRegister")
  100. @ApiOperation(value = "手机号密码注册")
  101. public String phonePwdLogin(String phone) {
  102. User user = userService.testPhoneRegister(phone);
  103. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  104. }
  105. @PostMapping("/mpLogin")
  106. @ApiOperation(value = "公众号登录")
  107. public String mpLogin(String code) {
  108. try {
  109. User user = userService.loginMp(code);
  110. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  111. } catch (Exception e) {
  112. log.error("loginByCode", e);
  113. throw new AuthenticationException("登陆错误", e);
  114. }
  115. }
  116. @PostMapping("/maLogin")
  117. @ApiOperation(value = "小程序登录")
  118. public String maLogin(String code) {
  119. try {
  120. User user = userService.loginMa(code);
  121. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  122. } catch (Exception e) {
  123. log.error("loginByCode", e);
  124. throw new AuthenticationException("登陆错误", e);
  125. }
  126. }
  127. @GetMapping("/getTime")
  128. public Long getTime() {
  129. return System.currentTimeMillis();
  130. }
  131. }