-
Notifications
You must be signed in to change notification settings - Fork 6
Expand file tree
/
Copy pathLoginMemberArgumentResolver.java
More file actions
62 lines (52 loc) · 2.34 KB
/
LoginMemberArgumentResolver.java
File metadata and controls
62 lines (52 loc) · 2.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
package com.yourssu.roomescape.auth;
import com.yourssu.roomescape.common.AppConstants;
import com.yourssu.roomescape.common.exception.UnauthorizedException;
import com.yourssu.roomescape.common.security.JwtTokenProvider;
import com.yourssu.roomescape.member.Member;
import com.yourssu.roomescape.member.MemberService;
import jakarta.servlet.http.Cookie;
import jakarta.servlet.http.HttpServletRequest;
import org.springframework.core.MethodParameter;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.support.WebDataBinderFactory;
import org.springframework.web.context.request.NativeWebRequest;
import org.springframework.web.method.support.HandlerMethodArgumentResolver;
import org.springframework.web.method.support.ModelAndViewContainer;
@Component
public class LoginMemberArgumentResolver implements HandlerMethodArgumentResolver {
private final MemberService memberService;
private final JwtTokenProvider jwtTokenProvider;
public LoginMemberArgumentResolver(MemberService memberService, JwtTokenProvider jwtTokenProvider) {
this.memberService = memberService;
this.jwtTokenProvider = jwtTokenProvider;
}
@Override
public boolean supportsParameter(MethodParameter parameter) {
return parameter.hasParameterAnnotation(LoginMember.class) && UserInfo.class.isAssignableFrom(parameter.getParameterType());
}
@Override
public Object resolveArgument(MethodParameter parameter, ModelAndViewContainer mavContainer,
NativeWebRequest webRequest, WebDataBinderFactory binderFactory) {
HttpServletRequest request = (HttpServletRequest) webRequest.getNativeRequest();
Cookie[] cookies = request.getCookies();
if (cookies == null) {
return null;
}
String token = "";
for (Cookie cookie : cookies) {
if (cookie.getName() != null && AppConstants.TOKEN_COOKIE_NAME.equals(cookie.getName())) {
token = cookie.getValue();
break;
}
}
if (token.isEmpty()) {
return null;
}
try {
String email = jwtTokenProvider.getPayload(token);
return memberService.findByEmail(email);
} catch (Exception e) {
throw new UnauthorizedException("Invalid credentials");
}
}
}