Skip to content

Commit 9b2b7e5

Browse files
Merge branch '5.8.x' into 6.0.x
Closes gh-14037
2 parents 758496f + 70ad3bf commit 9b2b7e5

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

+6-4
Original file line numberDiff line numberDiff line change
@@ -168,10 +168,12 @@ <T extends AbstractSaml2AuthenticationRequest> T resolve(HttpServletRequest requ
168168
.relayState(relayState)
169169
.id(authnRequest.getID());
170170
if (registration.getAssertingPartyDetails().getWantAuthnRequestsSigned()) {
171-
Map<String, String> parameters = OpenSamlSigningUtils.sign(registration)
172-
.param(Saml2ParameterNames.SAML_REQUEST, deflatedAndEncoded)
173-
.param(Saml2ParameterNames.RELAY_STATE, relayState)
174-
.parameters();
171+
OpenSamlSigningUtils.QueryParametersPartial parametersPartial = OpenSamlSigningUtils.sign(registration)
172+
.param(Saml2ParameterNames.SAML_REQUEST, deflatedAndEncoded);
173+
if (relayState != null) {
174+
parametersPartial = parametersPartial.param(Saml2ParameterNames.RELAY_STATE, relayState);
175+
}
176+
Map<String, String> parameters = parametersPartial.parameters();
175177
builder.sigAlg(parameters.get(Saml2ParameterNames.SIG_ALG))
176178
.signature(parameters.get(Saml2ParameterNames.SIGNATURE));
177179
}

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

+61
Original file line numberDiff line numberDiff line change
@@ -18,10 +18,13 @@
1818

1919
import org.junit.jupiter.api.BeforeEach;
2020
import org.junit.jupiter.api.Test;
21+
import org.mockito.Answers;
22+
import org.mockito.MockedStatic;
2123
import org.opensaml.xmlsec.signature.support.SignatureConstants;
2224

2325
import org.springframework.mock.web.MockHttpServletRequest;
2426
import org.springframework.security.saml2.Saml2Exception;
27+
import org.springframework.security.saml2.core.Saml2ParameterNames;
2528
import org.springframework.security.saml2.core.Saml2X509Credential;
2629
import org.springframework.security.saml2.core.TestSaml2X509Credentials;
2730
import org.springframework.security.saml2.provider.service.authentication.Saml2PostAuthenticationRequest;
@@ -32,6 +35,12 @@
3235

3336
import static org.assertj.core.api.Assertions.assertThat;
3437
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
38+
import static org.mockito.ArgumentMatchers.any;
39+
import static org.mockito.ArgumentMatchers.eq;
40+
import static org.mockito.Mockito.mockStatic;
41+
import static org.mockito.Mockito.never;
42+
import static org.mockito.Mockito.spy;
43+
import static org.mockito.Mockito.verify;
3544

3645
/**
3746
* Tests for {@link OpenSamlAuthenticationRequestResolver}
@@ -177,6 +186,58 @@ public void resolveAuthenticationRequestWhenSHA1SignRequestThenSigns() {
177186
assertThat(result.getId()).isNotEmpty();
178187
}
179188

189+
@Test
190+
public void resolveAuthenticationRequestWhenSignedAndRelayStateIsNullThenSignsWithoutRelayState() {
191+
try (MockedStatic<OpenSamlSigningUtils> openSamlSigningUtilsMockedStatic = mockStatic(
192+
OpenSamlSigningUtils.class, Answers.CALLS_REAL_METHODS)) {
193+
MockHttpServletRequest request = new MockHttpServletRequest();
194+
request.setPathInfo("/saml2/authenticate/registration-id");
195+
RelyingPartyRegistration registration = this.relyingPartyRegistrationBuilder
196+
.assertingPartyDetails((party) -> party.wantAuthnRequestsSigned(true))
197+
.build();
198+
OpenSamlSigningUtils.QueryParametersPartial queryParametersPartialSpy = spy(
199+
new OpenSamlSigningUtils.QueryParametersPartial(registration));
200+
openSamlSigningUtilsMockedStatic.when(() -> OpenSamlSigningUtils.sign(any()))
201+
.thenReturn(queryParametersPartialSpy);
202+
OpenSamlAuthenticationRequestResolver resolver = authenticationRequestResolver(registration);
203+
resolver.setRelayStateResolver((source) -> null);
204+
Saml2RedirectAuthenticationRequest result = resolver.resolve(request, (r, authnRequest) -> {
205+
});
206+
assertThat(result.getSamlRequest()).isNotEmpty();
207+
assertThat(result.getRelayState()).isNull();
208+
assertThat(result.getSigAlg()).isNotNull();
209+
assertThat(result.getSignature()).isNotNull();
210+
assertThat(result.getBinding()).isEqualTo(Saml2MessageBinding.REDIRECT);
211+
verify(queryParametersPartialSpy, never()).param(eq(Saml2ParameterNames.RELAY_STATE), any());
212+
}
213+
}
214+
215+
@Test
216+
public void resolveAuthenticationRequestWhenSignedAndRelayStateIsEmptyThenSignsWithEmptyRelayState() {
217+
try (MockedStatic<OpenSamlSigningUtils> openSamlSigningUtilsMockedStatic = mockStatic(
218+
OpenSamlSigningUtils.class, Answers.CALLS_REAL_METHODS)) {
219+
MockHttpServletRequest request = new MockHttpServletRequest();
220+
request.setPathInfo("/saml2/authenticate/registration-id");
221+
RelyingPartyRegistration registration = this.relyingPartyRegistrationBuilder
222+
.assertingPartyDetails((party) -> party.wantAuthnRequestsSigned(true))
223+
.build();
224+
OpenSamlSigningUtils.QueryParametersPartial queryParametersPartialSpy = spy(
225+
new OpenSamlSigningUtils.QueryParametersPartial(registration));
226+
openSamlSigningUtilsMockedStatic.when(() -> OpenSamlSigningUtils.sign(any()))
227+
.thenReturn(queryParametersPartialSpy);
228+
OpenSamlAuthenticationRequestResolver resolver = authenticationRequestResolver(registration);
229+
resolver.setRelayStateResolver((source) -> "");
230+
Saml2RedirectAuthenticationRequest result = resolver.resolve(request, (r, authnRequest) -> {
231+
});
232+
assertThat(result.getSamlRequest()).isNotEmpty();
233+
assertThat(result.getRelayState()).isEmpty();
234+
assertThat(result.getSigAlg()).isNotNull();
235+
assertThat(result.getSignature()).isNotNull();
236+
assertThat(result.getBinding()).isEqualTo(Saml2MessageBinding.REDIRECT);
237+
verify(queryParametersPartialSpy).param(eq(Saml2ParameterNames.RELAY_STATE), eq(""));
238+
}
239+
}
240+
180241
private OpenSamlAuthenticationRequestResolver authenticationRequestResolver(RelyingPartyRegistration registration) {
181242
return new OpenSamlAuthenticationRequestResolver((request, id) -> registration);
182243
}

0 commit comments

Comments
 (0)