SigninService.java 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package com.oqpo.api.service;
  2. import com.oqpo.api.config.JwtTokenProvider;
  3. import com.oqpo.api.constant.ApiConstants;
  4. import com.oqpo.api.entity.oper.MemberEntity;
  5. import com.oqpo.api.enums.SystemMessageCode;
  6. import com.oqpo.api.exception.GlobalException;
  7. import com.oqpo.api.mapper.MemberMapper;
  8. import com.oqpo.api.mapper.oper.UserMngMapper;
  9. import com.oqpo.api.service.oper.UserMngService;
  10. import com.oqpo.api.util.StringUtil;
  11. import com.oqpo.api.web.dto.response.oper.usermng.UserInfoResponse;
  12. import com.oqpo.api.web.dto.response.session.FindIdResponse;
  13. import com.oqpo.api.web.dto.response.session.FindPwResponse;
  14. import com.oqpo.api.web.dto.response.token.JwtResponse;
  15. import com.oqpo.api.web.dto.response.token.TokenResponse;
  16. import lombok.extern.slf4j.Slf4j;
  17. import org.springframework.beans.factory.annotation.Autowired;
  18. import org.springframework.security.authentication.AuthenticationManager;
  19. import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
  20. import org.springframework.security.core.Authentication;
  21. import org.springframework.security.core.GrantedAuthority;
  22. import org.springframework.security.core.authority.SimpleGrantedAuthority;
  23. import org.springframework.security.core.context.SecurityContextHolder;
  24. import org.springframework.security.core.userdetails.UserDetails;
  25. import org.springframework.security.core.userdetails.UserDetailsService;
  26. import org.springframework.security.core.userdetails.UsernameNotFoundException;
  27. import org.springframework.security.crypto.password.PasswordEncoder;
  28. import org.springframework.security.web.authentication.logout.SecurityContextLogoutHandler;
  29. import org.springframework.stereotype.Service;
  30. import javax.servlet.http.HttpServletRequest;
  31. import javax.servlet.http.HttpServletResponse;
  32. import java.util.ArrayList;
  33. import java.util.Collection;
  34. import java.util.List;
  35. @Service
  36. @Slf4j
  37. public class SigninService implements UserDetailsService {
  38. @Autowired
  39. private MemberMapper memberMapper;
  40. @Autowired
  41. private PasswordEncoder passwordEncoder;
  42. @Autowired
  43. private AuthenticationManager authenticationManager;
  44. @Autowired
  45. private JwtTokenProvider jwtTokenProvider;
  46. @Autowired
  47. private UserMngService userMngService ;
  48. public JwtResponse signin(String userId, String password) throws Exception {
  49. MemberEntity memberEntity = null;
  50. String connKey = "";
  51. try {
  52. UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken(userId, password);
  53. Authentication authentication = authenticationManager.authenticate(token);
  54. SecurityContextHolder.getContext().setAuthentication(authentication);
  55. memberEntity = (MemberEntity) authentication.getPrincipal();
  56. connKey = jwtTokenProvider.createToken (
  57. memberEntity.getUserId(),
  58. memberEntity.getUserNm(),
  59. memberEntity.getSystemAdminYn(),
  60. memberEntity.getAuthTpCd(),
  61. true,
  62. memberEntity.getAfflShopId(),
  63. memberEntity.getBrandId(),
  64. memberEntity.getAuthTpNm());
  65. log.debug("connKey==>>>{}", connKey);
  66. //로그인 이력 남기기
  67. userMngService.updateLoginDt(memberEntity.getUserId());
  68. } catch (Exception e) {
  69. e.getStackTrace();
  70. throw new GlobalException(SystemMessageCode.SIGNIN_FAIL);
  71. }
  72. return JwtResponse.toDTO(connKey);
  73. }
  74. public void logout(HttpServletRequest request, HttpServletResponse response) throws Exception {
  75. Authentication auth = SecurityContextHolder.getContext().getAuthentication();
  76. if (auth != null) {
  77. new SecurityContextLogoutHandler().logout(request, response, auth);
  78. }
  79. }
  80. public UserDetails getMember(String userId) {
  81. MemberEntity entity = memberMapper.selectMemberById(userId);
  82. entity.setAuthorities(getAuthorities());
  83. return entity;
  84. }
  85. @Override
  86. public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
  87. return getMember(username);
  88. }
  89. public Collection<GrantedAuthority> getAuthorities() {
  90. List<GrantedAuthority> authorities = new ArrayList<GrantedAuthority>();
  91. authorities.add(new SimpleGrantedAuthority("ROLE_SRM_MEMBER"));
  92. return authorities;
  93. }
  94. public PasswordEncoder passwordEncoder() {
  95. return this.passwordEncoder;
  96. }
  97. public FindIdResponse selectMemberFindId(String userNm, String email, String telNo) {
  98. MemberEntity entity = memberMapper.selectMemberFindId(userNm, email, telNo);
  99. if (entity == null) {
  100. throw new GlobalException(SystemMessageCode.ERR_FIND_ID);
  101. }
  102. return FindIdResponse.toDTO(entity);
  103. }
  104. public FindPwResponse selectMemberFindPw(String userId, String email, String telNo) throws Exception {
  105. String newpw = "";
  106. MemberEntity entity = new MemberEntity() ;
  107. int idCnt = memberMapper.selectMemberFindPwCnt(userId, email, telNo);
  108. if (idCnt == 0) {
  109. throw new GlobalException(SystemMessageCode.ERR_FIND_PW);
  110. } else {
  111. newpw = StringUtil.makeSecureString(6) ;
  112. entity.setUserId(userId);
  113. entity.setPassword(newpw);
  114. //패스워드 변경처리함
  115. userMngService.updateChgUserPw(userId, newpw);
  116. }
  117. return FindPwResponse.toDTO(entity);
  118. }
  119. }