Skip to content

Commit 30927ad

Browse files
committed
Polish gh-1011
1 parent 26205a2 commit 30927ad

File tree

2 files changed

+20
-28
lines changed

2 files changed

+20
-28
lines changed

oauth2-authorization-server/src/main/java/org/springframework/security/oauth2/server/authorization/web/OAuth2AuthorizationEndpointFilter.java

Lines changed: 11 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -18,9 +18,7 @@
1818
import java.io.IOException;
1919
import java.nio.charset.StandardCharsets;
2020
import java.util.Arrays;
21-
import java.util.HashMap;
2221
import java.util.HashSet;
23-
import java.util.Map;
2422
import java.util.Set;
2523

2624
import javax.servlet.FilterChain;
@@ -66,10 +64,8 @@
6664
import org.springframework.util.Assert;
6765
import org.springframework.util.StringUtils;
6866
import org.springframework.web.filter.OncePerRequestFilter;
69-
import org.springframework.web.util.DefaultUriBuilderFactory;
70-
import org.springframework.web.util.UriBuilder;
71-
import org.springframework.web.util.UriBuilderFactory;
7267
import org.springframework.web.util.UriComponentsBuilder;
68+
import org.springframework.web.util.UriUtils;
7369

7470
/**
7571
* A {@code Filter} for the OAuth 2.0 Authorization Code Grant,
@@ -299,18 +295,16 @@ private void sendAuthorizationResponse(HttpServletRequest request, HttpServletRe
299295

300296
OAuth2AuthorizationCodeRequestAuthenticationToken authorizationCodeRequestAuthentication =
301297
(OAuth2AuthorizationCodeRequestAuthenticationToken) authentication;
302-
UriBuilder uriBuilder = valuesOnlyEncodingUriBuilderFactory()
303-
.uriString(authorizationCodeRequestAuthentication.getRedirectUri())
298+
UriComponentsBuilder uriBuilder = UriComponentsBuilder
299+
.fromUriString(authorizationCodeRequestAuthentication.getRedirectUri())
304300
.queryParam(OAuth2ParameterNames.CODE, authorizationCodeRequestAuthentication.getAuthorizationCode().getTokenValue());
305301
String redirectUri;
306302
if (StringUtils.hasText(authorizationCodeRequestAuthentication.getState())) {
307-
uriBuilder.queryParam(OAuth2ParameterNames.STATE, "{state}");
308-
Map<String, String> queryParams = new HashMap<>();
309-
queryParams.put(OAuth2ParameterNames.STATE, authorizationCodeRequestAuthentication.getState());
310-
redirectUri = uriBuilder.build(queryParams).toString();
311-
} else {
312-
redirectUri = uriBuilder.build().toString();
303+
uriBuilder.queryParam(
304+
OAuth2ParameterNames.STATE,
305+
UriUtils.encode(authorizationCodeRequestAuthentication.getState(), StandardCharsets.UTF_8));
313306
}
307+
redirectUri = uriBuilder.build(true).toUriString(); // build(true) -> Components are explicitly encoded
314308
this.redirectStrategy.sendRedirect(request, response, redirectUri);
315309
}
316310

@@ -344,22 +338,14 @@ private void sendErrorResponse(HttpServletRequest request, HttpServletResponse r
344338
}
345339
String redirectUri;
346340
if (StringUtils.hasText(authorizationCodeRequestAuthentication.getState())) {
347-
uriBuilder.queryParam(OAuth2ParameterNames.STATE, "{state}");
348-
Map<String, String> queryParams = new HashMap<>();
349-
queryParams.put(OAuth2ParameterNames.STATE, authorizationCodeRequestAuthentication.getState());
350-
redirectUri = uriBuilder.build(queryParams).toString();
351-
} else {
352-
redirectUri = uriBuilder.toUriString();
341+
uriBuilder.queryParam(
342+
OAuth2ParameterNames.STATE,
343+
UriUtils.encode(authorizationCodeRequestAuthentication.getState(), StandardCharsets.UTF_8));
353344
}
345+
redirectUri = uriBuilder.build(true).toUriString(); // build(true) -> Components are explicitly encoded
354346
this.redirectStrategy.sendRedirect(request, response, redirectUri);
355347
}
356348

357-
private UriBuilderFactory valuesOnlyEncodingUriBuilderFactory() {
358-
DefaultUriBuilderFactory uriBuilderFactory = new DefaultUriBuilderFactory();
359-
uriBuilderFactory.setEncodingMode(DefaultUriBuilderFactory.EncodingMode.VALUES_ONLY);
360-
return uriBuilderFactory;
361-
}
362-
363349
/**
364350
* For internal use only.
365351
*/

oauth2-authorization-server/src/test/java/org/springframework/security/oauth2/server/authorization/config/annotation/web/configurers/OAuth2AuthorizationCodeGrantTests.java

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -286,7 +286,12 @@ public void requestWhenAuthorizationRequestCustomEndpointThenRedirectToClient()
286286
}
287287

288288
private void assertAuthorizationRequestRedirectsToClient(String authorizationEndpointUri) throws Exception {
289-
RegisteredClient registeredClient = TestRegisteredClients.registeredClient().build();
289+
RegisteredClient registeredClient = TestRegisteredClients.registeredClient()
290+
.redirectUris(redirectUris -> {
291+
redirectUris.clear();
292+
redirectUris.add("https://example.com/callback-1?param=encoded%20parameter%20value"); // gh-1011
293+
})
294+
.build();
290295
this.registeredClientRepository.save(registeredClient);
291296

292297
MultiValueMap<String, String> authorizationRequestParameters = getAuthorizationRequestParameters(registeredClient);
@@ -296,8 +301,9 @@ private void assertAuthorizationRequestRedirectsToClient(String authorizationEnd
296301
.andExpect(status().is3xxRedirection())
297302
.andReturn();
298303
String redirectedUrl = mvcResult.getResponse().getRedirectedUrl();
299-
String expectedRedirectUri = authorizationRequestParameters.getFirst(OAuth2ParameterNames.REDIRECT_URI);
300-
assertThat(redirectedUrl).matches(expectedRedirectUri + "\\?code=.{15,}&state=" + STATE_URL_ENCODED);
304+
String redirectUri = authorizationRequestParameters.getFirst(OAuth2ParameterNames.REDIRECT_URI);
305+
String code = extractParameterFromRedirectUri(redirectedUrl, "code");
306+
assertThat(redirectedUrl).isEqualTo(redirectUri + "&code=" + code + "&state=" + STATE_URL_ENCODED);
301307

302308
String authorizationCode = extractParameterFromRedirectUri(redirectedUrl, "code");
303309
OAuth2Authorization authorization = this.authorizationService.findByToken(authorizationCode, AUTHORIZATION_CODE_TOKEN_TYPE);

0 commit comments

Comments
 (0)