Skip to content

Commit

Permalink
Fix array values of additionalParameters
Browse files Browse the repository at this point in the history
Closes gh-15468
  • Loading branch information
chenzhenjia authored and sjohnr committed Sep 19, 2024
1 parent 0a4eb0f commit 8a79102
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,13 @@
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.function.Consumer;
import java.util.function.Function;

import java.util.stream.Stream;
import java.util.stream.StreamSupport;
import org.springframework.security.core.SpringSecurityCoreVersion;
import org.springframework.security.oauth2.core.AuthorizationGrantType;
import org.springframework.util.Assert;
Expand Down Expand Up @@ -463,7 +465,13 @@ private String buildAuthorizationRequestUri() {
Map<String, Object> parameters = getParameters(); // Not encoded
this.parametersConsumer.accept(parameters);
MultiValueMap<String, String> queryParams = new LinkedMultiValueMap<>();
parameters.forEach((k, v) -> queryParams.set(encodeQueryParam(k), encodeQueryParam(String.valueOf(v)))); // Encoded
parameters.forEach((key1, value) -> {
String key = encodeQueryParam(key1);
List<String> values = queryValues(value)
.map(o -> encodeQueryParam(String.valueOf(o)))
.toList();
queryParams.put(key, values);
});
UriBuilder uriBuilder = this.uriBuilderFactory.uriString(this.authorizationUri).queryParams(queryParams);
return this.authorizationRequestUriFunction.apply(uriBuilder).toString();
}
Expand All @@ -490,6 +498,20 @@ private static String encodeQueryParam(String value) {
return UriUtils.encodeQueryParam(value, StandardCharsets.UTF_8);
}

// Query value as a stream
// If the value is an Iterable or an array it will be converted to a stream
private static Stream<?> queryValues(Object value) {
if (value instanceof Iterable) {
return StreamSupport.stream(((Iterable<?>) value).spliterator(), false);

} else if (value.getClass().isArray()) {
return Arrays.stream((Object[]) value);

} else {
return Stream.of(value);
}
}

}

}
Original file line number Diff line number Diff line change
Expand Up @@ -16,20 +16,18 @@

package org.springframework.security.oauth2.core.endpoint;

import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatIllegalArgumentException;

import java.net.URI;
import java.util.Arrays;
import java.util.HashMap;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Set;

import org.junit.jupiter.api.Test;

import org.springframework.security.oauth2.core.AuthorizationGrantType;

import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatIllegalArgumentException;

/**
* Tests for {@link OAuth2AuthorizationRequest}.
*
Expand Down Expand Up @@ -364,4 +362,19 @@ public void buildWhenNonAsciiAdditionalParametersThenProperlyEncoded() {
+ "item%20amount=19.95%E2%82%AC&%C3%A2ge=4%C2%BD&item%20name=H%C3%85M%C3%96");
}

@Test
public void additionalParametersArrayValueOrIterableEncoded() {
Map<String, Object> additionalParameters = new HashMap<>();
additionalParameters.put("item", new String[] { "1", "2" });
additionalParameters.put("item2", Arrays.asList("H" + '\u00c5' + "M" + '\u00d6', "H" + '\u00c5' + "M" + '\u00d6'));
OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request()
.additionalParameters(additionalParameters)
.build();
assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull();
assertThat(authorizationRequest.getAuthorizationRequestUri()).isEqualTo(
"https://example.com/login/oauth/authorize?" + "response_type=code&client_id=client-id&state=state&"
+ "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&"
+ "item=1&item=2&item2=H%C3%85M%C3%96&item2=H%C3%85M%C3%96");
}

}

0 comments on commit 8a79102

Please sign in to comment.