mirror of
https://github.com/spring-projects/spring-security.git
synced 2025-05-31 17:22:13 +00:00
Polish gh-15533
This commit is contained in:
parent
24dbc5de53
commit
42d9f146d2
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2002-2022 the original author or authors.
|
* Copyright 2002-2024 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -23,13 +23,11 @@ import java.util.Arrays;
|
|||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
import java.util.function.Function;
|
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.core.SpringSecurityCoreVersion;
|
||||||
import org.springframework.security.oauth2.core.AuthorizationGrantType;
|
import org.springframework.security.oauth2.core.AuthorizationGrantType;
|
||||||
import org.springframework.util.Assert;
|
import org.springframework.util.Assert;
|
||||||
@ -442,12 +440,20 @@ public final class OAuth2AuthorizationRequest implements Serializable {
|
|||||||
Map<String, Object> parameters = getParameters(); // Not encoded
|
Map<String, Object> parameters = getParameters(); // Not encoded
|
||||||
this.parametersConsumer.accept(parameters);
|
this.parametersConsumer.accept(parameters);
|
||||||
MultiValueMap<String, String> queryParams = new LinkedMultiValueMap<>();
|
MultiValueMap<String, String> queryParams = new LinkedMultiValueMap<>();
|
||||||
parameters.forEach((key1, value) -> {
|
parameters.forEach((k, v) -> {
|
||||||
String key = encodeQueryParam(key1);
|
String key = encodeQueryParam(k);
|
||||||
List<String> values = queryValues(value)
|
if (v instanceof Iterable) {
|
||||||
.map(o -> encodeQueryParam(String.valueOf(o)))
|
((Iterable<?>) v).forEach((value) -> queryParams.add(key, encodeQueryParam(String.valueOf(value))));
|
||||||
.toList();
|
}
|
||||||
queryParams.put(key, values);
|
else if (v != null && v.getClass().isArray()) {
|
||||||
|
Object[] values = (Object[]) v;
|
||||||
|
for (Object value : values) {
|
||||||
|
queryParams.add(key, encodeQueryParam(String.valueOf(value)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
queryParams.set(key, encodeQueryParam(String.valueOf(v)));
|
||||||
|
}
|
||||||
});
|
});
|
||||||
UriBuilder uriBuilder = this.uriBuilderFactory.uriString(this.authorizationUri).queryParams(queryParams);
|
UriBuilder uriBuilder = this.uriBuilderFactory.uriString(this.authorizationUri).queryParams(queryParams);
|
||||||
return this.authorizationRequestUriFunction.apply(uriBuilder).toString();
|
return this.authorizationRequestUriFunction.apply(uriBuilder).toString();
|
||||||
@ -475,20 +481,6 @@ public final class OAuth2AuthorizationRequest implements Serializable {
|
|||||||
return UriUtils.encodeQueryParam(value, StandardCharsets.UTF_8);
|
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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2002-2022 the original author or authors.
|
* Copyright 2002-2024 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -16,18 +16,21 @@
|
|||||||
|
|
||||||
package org.springframework.security.oauth2.core.endpoint;
|
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.net.URI;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import org.springframework.security.oauth2.core.AuthorizationGrantType;
|
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}.
|
* Tests for {@link OAuth2AuthorizationRequest}.
|
||||||
*
|
*
|
||||||
@ -318,18 +321,48 @@ public class OAuth2AuthorizationRequestTests {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void additionalParametersArrayValueOrIterableEncoded() {
|
public void buildWhenAdditionalParametersContainsArrayThenProperlyEncoded() {
|
||||||
Map<String, Object> additionalParameters = new HashMap<>();
|
Map<String, Object> additionalParameters = new LinkedHashMap<>();
|
||||||
additionalParameters.put("item", new String[] { "1", "2" });
|
additionalParameters.put("item1", new String[] { "1", "2" });
|
||||||
additionalParameters.put("item2", Arrays.asList("H" + '\u00c5' + "M" + '\u00d6', "H" + '\u00c5' + "M" + '\u00d6'));
|
additionalParameters.put("item2", "value2");
|
||||||
OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request()
|
OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request()
|
||||||
.additionalParameters(additionalParameters)
|
.additionalParameters(additionalParameters)
|
||||||
.build();
|
.build();
|
||||||
assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull();
|
assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull();
|
||||||
assertThat(authorizationRequest.getAuthorizationRequestUri()).isEqualTo(
|
assertThat(authorizationRequest.getAuthorizationRequestUri())
|
||||||
"https://example.com/login/oauth/authorize?" + "response_type=code&client_id=client-id&state=state&"
|
.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&"
|
+ "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");
|
+ "item1=1&item1=2&item2=value2");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void buildWhenAdditionalParametersContainsIterableThenProperlyEncoded() {
|
||||||
|
Map<String, Object> additionalParameters = new LinkedHashMap<>();
|
||||||
|
additionalParameters.put("item1", Arrays.asList("1", "2"));
|
||||||
|
additionalParameters.put("item2", "value2");
|
||||||
|
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&"
|
||||||
|
+ "item1=1&item1=2&item2=value2");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void buildWhenAdditionalParametersContainsNullThenAuthorizationRequestUriContainsNull() {
|
||||||
|
Map<String, Object> additionalParameters = new LinkedHashMap<>();
|
||||||
|
additionalParameters.put("item1", null);
|
||||||
|
additionalParameters.put("item2", "value2");
|
||||||
|
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&"
|
||||||
|
+ "item1=null&item2=value2");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user