From 7dd5cc6082fdbc7c5b82707ec250d7e7f4364a5d Mon Sep 17 00:00:00 2001 From: Tobias Meurer Date: Thu, 2 Feb 2023 14:06:54 +0100 Subject: [PATCH] Pick Up Custom SecurityContextRespository Closes gh-12579 --- .../web/configurers/SessionManagementConfigurer.java | 3 +++ .../SessionManagementConfigurerTests.java | 12 ++++++++++++ 2 files changed, 15 insertions(+) diff --git a/config/src/main/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurer.java b/config/src/main/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurer.java index 2542fcb438..58dd5f9e10 100644 --- a/config/src/main/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurer.java +++ b/config/src/main/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurer.java @@ -380,6 +380,9 @@ public final class SessionManagementConfigurer> http.setSharedObject(SecurityContextRepository.class, defaultRepository); } } + else { + this.sessionManagementSecurityContextRepository = securityContextRepository; + } RequestCache requestCache = http.getSharedObject(RequestCache.class); if (requestCache == null) { if (stateless) { diff --git a/config/src/test/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurerTests.java b/config/src/test/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurerTests.java index c4564441db..989948a82a 100644 --- a/config/src/test/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurerTests.java +++ b/config/src/test/java/org/springframework/security/config/annotation/web/configurers/SessionManagementConfigurerTests.java @@ -125,6 +125,18 @@ public class SessionManagementConfigurerTests { this.mvc.perform(get("/")); } + @Test + public void sessionManagementWhenSecurityContextRepositoryIsConfiguredThenUseIt() throws Exception { + SessionManagementSecurityContextRepositoryConfig.SECURITY_CONTEXT_REPO = mock(SecurityContextRepository.class); + given(SessionManagementSecurityContextRepositoryConfig.SECURITY_CONTEXT_REPO + .loadDeferredContext(any(HttpServletRequest.class))) + .willReturn(new TestDeferredSecurityContext(mock(SecurityContext.class), false)); + this.spring.register(SessionManagementSecurityContextRepositoryConfig.class).autowire(); + this.mvc.perform(get("/")); + verify(SessionManagementSecurityContextRepositoryConfig.SECURITY_CONTEXT_REPO) + .containsContext(any(HttpServletRequest.class)); + } + @Test public void sessionManagementWhenInvokedTwiceThenUsesOriginalSessionCreationPolicy() throws Exception { this.spring.register(InvokeTwiceDoesNotOverride.class).autowire();