Skip to content

Commit 0bc8825

Browse files
Add session to both header and cookie, possibility to authenticate with token (#151)
1 parent 61e29e3 commit 0bc8825

File tree

2 files changed

+50
-1
lines changed

2 files changed

+50
-1
lines changed
Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
package com.ericsson.ei.config;
2+
3+
import java.util.Collections;
4+
import java.util.List;
5+
6+
import javax.servlet.http.HttpServletRequest;
7+
import javax.servlet.http.HttpServletResponse;
8+
9+
import org.springframework.session.web.http.CookieSerializer;
10+
import org.springframework.session.web.http.CookieSerializer.CookieValue;
11+
import org.springframework.session.web.http.DefaultCookieSerializer;
12+
import org.springframework.session.web.http.HttpSessionIdResolver;
13+
14+
public final class HeaderAndCookieHttpSessionIdResolver implements HttpSessionIdResolver {
15+
16+
private static final String X_AUTH_TOKEN = "X-Auth-Token";
17+
private static final String WRITTEN_SESSION_ID_ATTR = HeaderAndCookieHttpSessionIdResolver.class.getName()
18+
.concat(".WRITTEN_SESSION_ID_ATTR");
19+
20+
private CookieSerializer cookieSerializer = new DefaultCookieSerializer();
21+
22+
@Override
23+
public List<String> resolveSessionIds(HttpServletRequest request) {
24+
String headerValue = request.getHeader(X_AUTH_TOKEN);
25+
return (headerValue != null ? Collections.singletonList(headerValue)
26+
: this.cookieSerializer.readCookieValues(request));
27+
}
28+
29+
@Override
30+
public void setSessionId(HttpServletRequest request, HttpServletResponse response, String sessionId) {
31+
response.setHeader(X_AUTH_TOKEN, sessionId);
32+
if (sessionId.equals(request.getAttribute(WRITTEN_SESSION_ID_ATTR))) {
33+
return;
34+
}
35+
request.setAttribute(WRITTEN_SESSION_ID_ATTR, sessionId);
36+
this.cookieSerializer.writeCookieValue(new CookieValue(request, response, sessionId));
37+
}
38+
39+
@Override
40+
public void expireSession(HttpServletRequest request, HttpServletResponse response) {
41+
response.setHeader(X_AUTH_TOKEN, "");
42+
this.cookieSerializer.writeCookieValue(new CookieValue(request, response, ""));
43+
}
44+
}

src/main/java/com/ericsson/ei/config/HttpSessionConfig.java

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
import org.springframework.security.core.context.SecurityContextHolder;
88
import org.springframework.session.data.mongo.MongoOperationsSessionRepository;
99
import org.springframework.session.data.mongo.config.annotation.web.http.EnableMongoHttpSession;
10+
import org.springframework.session.web.http.HttpSessionIdResolver;
1011

1112
@EnableMongoHttpSession()
1213
public class HttpSessionConfig {
@@ -28,5 +29,9 @@ public MongoOperationsSessionRepository mongoSessionRepository(MongoOperations m
2829
public static String getCurrentUser() {
2930
return SecurityContextHolder.getContext().getAuthentication().getName();
3031
}
31-
32+
33+
@Bean
34+
public HttpSessionIdResolver httpSessionIdResolver() {
35+
return new HeaderAndCookieHttpSessionIdResolver();
36+
}
3237
}

0 commit comments

Comments
 (0)