AuthenticationController.java 5.7 KB

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