Skip to content

Commit 8ca7d19

Browse files
Merge branch '6.0.x' into 6.1.x
Closes gh-14038
2 parents 781d9d8 + 9b2b7e5 commit 8ca7d19

File tree

2 files changed

+67
-4
lines changed

2 files changed

+67
-4
lines changed

saml2/saml2-service-provider/src/main/java/org/springframework/security/saml2/provider/service/web/authentication/OpenSamlAuthenticationRequestResolver.java

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -176,10 +176,12 @@ <T extends AbstractSaml2AuthenticationRequest> T resolve(HttpServletRequest requ
176176
.id(authnRequest.getID());
177177
if (registration.getAssertingPartyDetails().getWantAuthnRequestsSigned()
178178
|| registration.isAuthnRequestsSigned()) {
179-
Map<String, String> parameters = OpenSamlSigningUtils.sign(registration)
180-
.param(Saml2ParameterNames.SAML_REQUEST, deflatedAndEncoded)
181-
.param(Saml2ParameterNames.RELAY_STATE, relayState)
182-
.parameters();
179+
OpenSamlSigningUtils.QueryParametersPartial parametersPartial = OpenSamlSigningUtils.sign(registration)
180+
.param(Saml2ParameterNames.SAML_REQUEST, deflatedAndEncoded);
181+
if (relayState != null) {
182+
parametersPartial = parametersPartial.param(Saml2ParameterNames.RELAY_STATE, relayState);
183+
}
184+
Map<String, String> parameters = parametersPartial.parameters();
183185
builder.sigAlg(parameters.get(Saml2ParameterNames.SIG_ALG))
184186
.signature(parameters.get(Saml2ParameterNames.SIGNATURE));
185187
}

saml2/saml2-service-provider/src/test/java/org/springframework/security/saml2/provider/service/web/authentication/OpenSamlAuthenticationRequestResolverTests.java

Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -23,10 +23,13 @@
2323
import org.junit.jupiter.params.ParameterizedTest;
2424
import org.junit.jupiter.params.provider.Arguments;
2525
import org.junit.jupiter.params.provider.MethodSource;
26+
import org.mockito.Answers;
27+
import org.mockito.MockedStatic;
2628
import org.opensaml.xmlsec.signature.support.SignatureConstants;
2729

2830
import org.springframework.mock.web.MockHttpServletRequest;
2931
import org.springframework.security.saml2.Saml2Exception;
32+
import org.springframework.security.saml2.core.Saml2ParameterNames;
3033
import org.springframework.security.saml2.core.Saml2X509Credential;
3134
import org.springframework.security.saml2.core.TestSaml2X509Credentials;
3235
import org.springframework.security.saml2.provider.service.authentication.Saml2PostAuthenticationRequest;
@@ -39,6 +42,12 @@
3942

4043
import static org.assertj.core.api.Assertions.assertThat;
4144
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
45+
import static org.mockito.ArgumentMatchers.any;
46+
import static org.mockito.ArgumentMatchers.eq;
47+
import static org.mockito.Mockito.mockStatic;
48+
import static org.mockito.Mockito.never;
49+
import static org.mockito.Mockito.spy;
50+
import static org.mockito.Mockito.verify;
4251

4352
/**
4453
* Tests for {@link OpenSamlAuthenticationRequestResolver}
@@ -198,6 +207,58 @@ public void resolveAuthenticationRequestWhenSHA1SignRequestThenSigns() {
198207
assertThat(result.getId()).isNotEmpty();
199208
}
200209

210+
@Test
211+
public void resolveAuthenticationRequestWhenSignedAndRelayStateIsNullThenSignsWithoutRelayState() {
212+
try (MockedStatic<OpenSamlSigningUtils> openSamlSigningUtilsMockedStatic = mockStatic(
213+
OpenSamlSigningUtils.class, Answers.CALLS_REAL_METHODS)) {
214+
MockHttpServletRequest request = new MockHttpServletRequest();
215+
request.setPathInfo("/saml2/authenticate/registration-id");
216+
RelyingPartyRegistration registration = this.relyingPartyRegistrationBuilder
217+
.assertingPartyDetails((party) -> party.wantAuthnRequestsSigned(true))
218+
.build();
219+
OpenSamlSigningUtils.QueryParametersPartial queryParametersPartialSpy = spy(
220+
new OpenSamlSigningUtils.QueryParametersPartial(registration));
221+
openSamlSigningUtilsMockedStatic.when(() -> OpenSamlSigningUtils.sign(any()))
222+
.thenReturn(queryParametersPartialSpy);
223+
OpenSamlAuthenticationRequestResolver resolver = authenticationRequestResolver(registration);
224+
resolver.setRelayStateResolver((source) -> null);
225+
Saml2RedirectAuthenticationRequest result = resolver.resolve(request, (r, authnRequest) -> {
226+
});
227+
assertThat(result.getSamlRequest()).isNotEmpty();
228+
assertThat(result.getRelayState()).isNull();
229+
assertThat(result.getSigAlg()).isNotNull();
230+
assertThat(result.getSignature()).isNotNull();
231+
assertThat(result.getBinding()).isEqualTo(Saml2MessageBinding.REDIRECT);
232+
verify(queryParametersPartialSpy, never()).param(eq(Saml2ParameterNames.RELAY_STATE), any());
233+
}
234+
}
235+
236+
@Test
237+
public void resolveAuthenticationRequestWhenSignedAndRelayStateIsEmptyThenSignsWithEmptyRelayState() {
238+
try (MockedStatic<OpenSamlSigningUtils> openSamlSigningUtilsMockedStatic = mockStatic(
239+
OpenSamlSigningUtils.class, Answers.CALLS_REAL_METHODS)) {
240+
MockHttpServletRequest request = new MockHttpServletRequest();
241+
request.setPathInfo("/saml2/authenticate/registration-id");
242+
RelyingPartyRegistration registration = this.relyingPartyRegistrationBuilder
243+
.assertingPartyDetails((party) -> party.wantAuthnRequestsSigned(true))
244+
.build();
245+
OpenSamlSigningUtils.QueryParametersPartial queryParametersPartialSpy = spy(
246+
new OpenSamlSigningUtils.QueryParametersPartial(registration));
247+
openSamlSigningUtilsMockedStatic.when(() -> OpenSamlSigningUtils.sign(any()))
248+
.thenReturn(queryParametersPartialSpy);
249+
OpenSamlAuthenticationRequestResolver resolver = authenticationRequestResolver(registration);
250+
resolver.setRelayStateResolver((source) -> "");
251+
Saml2RedirectAuthenticationRequest result = resolver.resolve(request, (r, authnRequest) -> {
252+
});
253+
assertThat(result.getSamlRequest()).isNotEmpty();
254+
assertThat(result.getRelayState()).isEmpty();
255+
assertThat(result.getSigAlg()).isNotNull();
256+
assertThat(result.getSignature()).isNotNull();
257+
assertThat(result.getBinding()).isEqualTo(Saml2MessageBinding.REDIRECT);
258+
verify(queryParametersPartialSpy).param(eq(Saml2ParameterNames.RELAY_STATE), eq(""));
259+
}
260+
}
261+
201262
private OpenSamlAuthenticationRequestResolver authenticationRequestResolver(RelyingPartyRegistration registration) {
202263
return new OpenSamlAuthenticationRequestResolver((request, id) -> registration);
203264
}

0 commit comments

Comments
 (0)