Skip to content

Commit 320bfdf

Browse files
committed
Polish
1 parent c98e01a commit 320bfdf

File tree

2 files changed

+30
-20
lines changed

2 files changed

+30
-20
lines changed

spring-web/src/main/java/org/springframework/web/server/session/HeaderSessionIdResolver.java renamed to spring-web/src/main/java/org/springframework/web/server/session/HeaderWebSessionIdResolver.java

Lines changed: 11 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright 2017 the original author or authors.
2+
* Copyright 2002-2017 the original author or authors.
33
*
44
* Licensed under the Apache License, Version 2.0 (the "License");
55
* you may not use this file except in compliance with the License.
@@ -23,18 +23,21 @@
2323
import org.springframework.web.server.ServerWebExchange;
2424

2525
/**
26-
* Header-based {@link WebSessionIdResolver}.
26+
* Request and response header-based {@link WebSessionIdResolver}.
2727
*
2828
* @author Greg Turnquist
2929
* @since 5.0
3030
*/
31-
public class HeaderSessionIdResolver implements WebSessionIdResolver {
31+
public class HeaderWebSessionIdResolver implements WebSessionIdResolver {
3232

3333
private String headerName = "SESSION";
3434

35+
3536
/**
3637
* Set the name of the session header to use for the session id.
37-
* <p>By default set to "SESSION".
38+
* The name is used to extract the session id from the request headers as
39+
* well to set the session id on the response headers.
40+
* <p>By default set to {@literal "SESSION"}.
3841
* @param headerName the header name
3942
*/
4043
public void setHeaderName(String headerName) {
@@ -49,24 +52,22 @@ public String getHeaderName() {
4952
return this.headerName;
5053
}
5154

55+
5256
@Override
5357
public List<String> resolveSessionIds(ServerWebExchange exchange) {
5458
HttpHeaders headers = exchange.getRequest().getHeaders();
55-
List<String> sessionHeaders = headers.get(this.getHeaderName());
56-
if (sessionHeaders == null) {
57-
return Collections.emptyList();
58-
}
59-
return sessionHeaders;
59+
return headers.getOrDefault(getHeaderName(), Collections.emptyList());
6060
}
6161

6262
@Override
6363
public void setSessionId(ServerWebExchange exchange, String id) {
6464
Assert.notNull(id, "'id' is required.");
65-
exchange.getResponse().getHeaders().set(this.headerName, id);
65+
exchange.getResponse().getHeaders().set(getHeaderName(), id);
6666
}
6767

6868
@Override
6969
public void expireSession(ServerWebExchange exchange) {
7070
this.setSessionId(exchange, "");
7171
}
72+
7273
}

spring-web/src/test/java/org/springframework/web/server/session/HeaderSessionIdResolverTests.java renamed to spring-web/src/test/java/org/springframework/web/server/session/HeaderWebSessionIdResolverTests.java

Lines changed: 19 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright 2017 the original author or authors.
2+
* Copyright 2002-2017 the original author or authors.
33
*
44
* Licensed under the Apache License, Version 2.0 (the "License");
55
* you may not use this file except in compliance with the License.
@@ -15,11 +15,6 @@
1515
*/
1616
package org.springframework.web.server.session;
1717

18-
import static org.hamcrest.collection.IsCollectionWithSize.*;
19-
import static org.hamcrest.core.Is.*;
20-
import static org.hamcrest.core.IsCollectionContaining.*;
21-
import static org.junit.Assert.*;
22-
2318
import java.time.Clock;
2419
import java.time.Duration;
2520
import java.time.Instant;
@@ -29,6 +24,7 @@
2924
import org.junit.Before;
3025
import org.junit.Test;
3126
import reactor.core.publisher.Mono;
27+
3228
import org.springframework.http.codec.ServerCodecConfigurer;
3329
import org.springframework.mock.http.server.reactive.test.MockServerHttpRequest;
3430
import org.springframework.mock.http.server.reactive.test.MockServerHttpResponse;
@@ -37,24 +33,36 @@
3733
import org.springframework.web.server.adapter.DefaultServerWebExchange;
3834
import org.springframework.web.server.i18n.AcceptHeaderLocaleContextResolver;
3935

36+
import static org.hamcrest.collection.IsCollectionWithSize.hasSize;
37+
import static org.hamcrest.core.Is.is;
38+
import static org.hamcrest.core.IsCollectionContaining.hasItem;
39+
import static org.junit.Assert.assertEquals;
40+
import static org.junit.Assert.assertFalse;
41+
import static org.junit.Assert.assertNotNull;
42+
import static org.junit.Assert.assertNotSame;
43+
import static org.junit.Assert.assertNull;
44+
import static org.junit.Assert.assertThat;
45+
4046
/**
41-
* Tests using {@link HeaderSessionIdResolver}.
47+
* Tests using {@link HeaderWebSessionIdResolver}.
4248
*
4349
* @author Greg Turnquist
4450
*/
45-
public class HeaderSessionIdResolverTests {
51+
public class HeaderWebSessionIdResolverTests {
4652

4753
private static final Clock CLOCK = Clock.system(ZoneId.of("GMT"));
4854

49-
private HeaderSessionIdResolver idResolver;
55+
56+
private HeaderWebSessionIdResolver idResolver;
5057

5158
private DefaultWebSessionManager manager;
5259

5360
private ServerWebExchange exchange;
5461

62+
5563
@Before
5664
public void setUp() {
57-
this.idResolver = new HeaderSessionIdResolver();
65+
this.idResolver = new HeaderWebSessionIdResolver();
5866
this.manager = new DefaultWebSessionManager();
5967
this.manager.setSessionIdResolver(this.idResolver);
6068

@@ -172,4 +180,5 @@ public void alternateHeaderName() throws Exception {
172180
private DefaultWebSession createDefaultWebSession(UUID sessionId) {
173181
return new DefaultWebSession(() -> sessionId, CLOCK, (s, session) -> Mono.empty(), s -> Mono.empty());
174182
}
183+
175184
}

0 commit comments

Comments
 (0)