-
Notifications
You must be signed in to change notification settings - Fork 2
/
CookieProvider.java
33 lines (26 loc) · 991 Bytes
/
CookieProvider.java
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
package com.example.backend.global.security;
import com.example.backend.global.security.jwt.JwtConfig;
import lombok.RequiredArgsConstructor;
import org.springframework.http.ResponseCookie;
import org.springframework.stereotype.Component;
@Component
@RequiredArgsConstructor
public class CookieProvider {
private final JwtConfig jwtConfig;
private String REFRESH_COOKIE = "refreshToken";
public ResponseCookie createRefreshTokenCookie(String refreshToken){
deleteRefreshTokenCookie();
return ResponseCookie.from(REFRESH_COOKIE, refreshToken)
.httpOnly(true)
.secure(false) //TODO SSL 인증서 필요해서 나중에
.sameSite("None")
.maxAge(jwtConfig.getRefreshExpiry())
.path("/refresh")
.build();
}
public void deleteRefreshTokenCookie(){
ResponseCookie.from(REFRESH_COOKIE, "")
.maxAge(1)
.build();
}
}