AuthenticationController.java 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.MetaTourist;
  3. import com.izouma.nineth.domain.User;
  4. import com.izouma.nineth.dto.MetaRestResult;
  5. import com.izouma.nineth.dto.MetaTouristDTO;
  6. import com.izouma.nineth.dto.MetaUserDTO;
  7. import com.izouma.nineth.enums.AuthorityName;
  8. import com.izouma.nineth.enums.InviteType;
  9. import com.izouma.nineth.exception.AuthenticationException;
  10. import com.izouma.nineth.exception.BusinessException;
  11. import com.izouma.nineth.repo.AssetRepo;
  12. import com.izouma.nineth.repo.MetaTouristRepo;
  13. import com.izouma.nineth.security.JwtTokenUtil;
  14. import com.izouma.nineth.security.JwtUserFactory;
  15. import com.izouma.nineth.service.ContentAuditService;
  16. import com.izouma.nineth.service.UserService;
  17. import io.swagger.annotations.ApiOperation;
  18. import lombok.AllArgsConstructor;
  19. import lombok.extern.slf4j.Slf4j;
  20. import org.apache.commons.lang3.RandomStringUtils;
  21. import org.apache.commons.lang3.StringUtils;
  22. import org.springframework.security.authentication.AuthenticationManager;
  23. import org.springframework.web.bind.annotation.*;
  24. import java.util.HashMap;
  25. import java.util.Map;
  26. @Slf4j
  27. @AllArgsConstructor
  28. @RestController
  29. @RequestMapping("/auth")
  30. public class AuthenticationController {
  31. private final AuthenticationManager authenticationManager;
  32. private final JwtTokenUtil jwtTokenUtil;
  33. private final UserService userService;
  34. private ContentAuditService contentAuditService;
  35. private MetaTouristRepo metaTouristRepo;
  36. private AssetRepo assetRepo;
  37. @PostMapping("/login")
  38. public String loginByUserPwd(String username, String password, Integer expiration) {
  39. User user = userService.loginByUsernamePwd(username, password);
  40. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  41. }
  42. @PostMapping("/oasisLogin")
  43. public Map<String, Object> oasisLogin(String phone, String password, Integer expiration) {
  44. User user = userService.loginByPhonePwd(phone, password);
  45. Map<String, Object> result = userService.oasisInfo(user.getId());
  46. result.put("token", jwtTokenUtil.generateToken(JwtUserFactory.create(user)));
  47. result.put("userId", user.getId());
  48. return result;
  49. }
  50. @PostMapping("/oasisLoginPhone")
  51. public Map<String, Object> oasisLogin(String phone, String code) {
  52. User user = userService.loginByPhone(phone, code);
  53. Map<String, Object> result = userService.oasisInfo(user.getId());
  54. result.put("token", jwtTokenUtil.generateToken(JwtUserFactory.create(user)));
  55. result.put("userId", user.getId());
  56. return result;
  57. }
  58. @PostMapping("/loginAdmin")
  59. public String loginByUserPwdAdmin(String username, String password, Integer expiration) {
  60. User user = userService.loginByUsernamePwd(username, password);
  61. if (user.getAuthorities() == null ||
  62. user.getAuthorities().stream().anyMatch(au -> au.getName().equals(AuthorityName.ROLE_ADMIN.name()))) {
  63. throw new AuthenticationException("禁止登录", null);
  64. }
  65. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  66. }
  67. @PostMapping("/phoneLogin")
  68. @ApiOperation(value = "手机号验证码登录")
  69. public String phoneLogin(String phone, String code, @RequestParam(required = false) Long invitor) {
  70. User user = userService.loginByPhone(phone, code);
  71. InviteType userInviteType = user.getInviteType();
  72. if (invitor != null) {
  73. if (userInviteType != null) {
  74. if (!userInviteType.equals(InviteType.AUCTION)) {
  75. userService.bindAuctionInvitor(user.getId(), invitor);
  76. }
  77. } else {
  78. userService.bindAuctionInvitor(user.getId(), invitor);
  79. }
  80. }
  81. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  82. }
  83. @PostMapping("/metaPhoneLogin")
  84. @ApiOperation(value = "元宇宙手机号验证码登录")
  85. public MetaRestResult<MetaUserDTO> metaPhoneLogin(String phone, String code) {
  86. User user = userService.loginByPhone(phone, code);
  87. String token = jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  88. return MetaRestResult.returnSuccess(MetaUserDTO.create(user, token));
  89. }
  90. @PostMapping("/phonePwdLogin")
  91. @ApiOperation(value = "手机号密码登录")
  92. public String phonePwdLogin(String phone, String password, @RequestParam(required = false) Long invitor) {
  93. User user = userService.loginByPhonePwd(phone, password);
  94. InviteType userInviteType = user.getInviteType();
  95. if (invitor != null) {
  96. if (userInviteType != null) {
  97. if (!userInviteType.equals(InviteType.AUCTION)) {
  98. userService.bindAuctionInvitor(user.getId(), invitor);
  99. }
  100. } else {
  101. userService.bindAuctionInvitor(user.getId(), invitor);
  102. }
  103. }
  104. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  105. }
  106. @PostMapping("/metaPhonePwdLogin")
  107. @ApiOperation(value = "元宇宙手机号密码登录")
  108. public MetaRestResult<MetaUserDTO> metaPhonePwdLogin(String phone, String password) {
  109. User user = userService.loginByPhonePwd(phone, password);
  110. String token = jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  111. return MetaRestResult.returnSuccess(MetaUserDTO.create(user, token));
  112. }
  113. @PostMapping("/metaDomainPwdLogin")
  114. @ApiOperation(value = "元宇宙元域名密码登录")
  115. public MetaRestResult<MetaUserDTO> metaDomainPwdLogin(String name, String password) {
  116. String phone = assetRepo.findPhone("RID元宇宙域名 ".concat(name).concat(".nft"));
  117. if (StringUtils.isEmpty(phone)){
  118. return MetaRestResult.returnError("此域名暂无用户持有");
  119. }
  120. User user = userService.loginByPhonePwd(phone, password);
  121. String token = jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  122. return MetaRestResult.returnSuccess(MetaUserDTO.create(user, token));
  123. }
  124. @PostMapping("/tradingLogin")
  125. public Object tradingLogin(String phone, String password, String tradeCode) {
  126. return userService.loginTrading(phone, password, tradeCode);
  127. }
  128. @PostMapping("/phoneRegister")
  129. @ApiOperation(value = "手机号密码注册")
  130. public String phonePwdLogin(String phone, String code, String password, String inviteCode, Long invitor,
  131. Long collectionId, Long showroomId, InviteType inviteType) {
  132. User user = userService
  133. .phoneRegister(phone, code, password, inviteCode, invitor, collectionId, showroomId, inviteType, null);
  134. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  135. }
  136. @PostMapping("/meta/phoneRegister")
  137. @ApiOperation(value = "元宇宙手机号密码注册")
  138. public String metaPhonePwdLogin(String phone, String code, String password, String inviteCode, Long invitor,
  139. Long collectionId, Long showroomId, InviteType inviteType, String name) {
  140. if (!contentAuditService.auditText(name)) {
  141. throw new BusinessException("昵称包含不合法内容!");
  142. }
  143. User user = userService
  144. .phoneRegister(phone, code, password, inviteCode, invitor, collectionId, showroomId, inviteType, name);
  145. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  146. }
  147. @PostMapping("/mqPhoneRegister")
  148. @ApiOperation(value = "手机号密码注册")
  149. public String mqPhoneRegister(String phone, String code, String password, String inviteCode, Long invitor,
  150. Long collectionId, Long showroomId) {
  151. // boolean verify = captchaService.verify(captchaKey, captcha);
  152. // if (!verify) {
  153. // throw new BusinessException("验证码错误");
  154. // }
  155. return userService.mqRegister(phone, code, password, inviteCode, invitor, collectionId, showroomId);
  156. }
  157. @GetMapping("/registerResult")
  158. public Object registerResult(String phone) {
  159. Object res = userService.getRegisterResult(phone);
  160. Map<String, Object> map = new HashMap<>();
  161. if (res == null) {
  162. map.put("status", "pending");
  163. return map;
  164. } else {
  165. return res;
  166. }
  167. }
  168. @PostMapping("/mpLogin")
  169. @ApiOperation(value = "公众号登录")
  170. public String mpLogin(String code) {
  171. try {
  172. User user = userService.loginMp(code);
  173. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  174. } catch (Exception e) {
  175. log.error("loginByCode", e);
  176. throw new AuthenticationException("登陆错误", e);
  177. }
  178. }
  179. @PostMapping("/maLogin")
  180. @ApiOperation(value = "小程序登录")
  181. public String maLogin(String code) {
  182. try {
  183. User user = userService.loginMa(code);
  184. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  185. } catch (Exception e) {
  186. log.error("loginByCode", e);
  187. throw new AuthenticationException("登陆错误", e);
  188. }
  189. }
  190. @GetMapping("/getTime")
  191. public Long getTime() {
  192. return System.currentTimeMillis();
  193. }
  194. @PostMapping("/oneKeyLogin")
  195. public String oneKeyLogin(String umengKey, String token) {
  196. User user = userService.oneKeyLogin(umengKey, token);
  197. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  198. }
  199. @GetMapping("/touristLogin")
  200. public MetaTouristDTO touristLogin() {
  201. MetaTourist save = metaTouristRepo.save(new MetaTourist());
  202. MetaTouristDTO metaTouristDTO = new MetaTouristDTO();
  203. metaTouristDTO.setUserId(-save.getUserId());
  204. metaTouristDTO.setNickname("游客-" + RandomStringUtils.randomAlphabetic(8));
  205. return metaTouristDTO;
  206. }
  207. }