mirror of
https://github.com/nextcloud/android.git
synced 2024-11-26 07:05:49 +03:00
Merge pull request #7995 from nextcloud/parameterV2
SSO: support of parameter v2, which allows to have multiple values for same key
This commit is contained in:
commit
5b2398bf0c
4 changed files with 154 additions and 3 deletions
|
@ -0,0 +1,61 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* Nextcloud Android client application
|
||||||
|
*
|
||||||
|
* @author Tobias Kaminsky
|
||||||
|
* Copyright (C) 2021 Tobias Kaminsky
|
||||||
|
* Copyright (C) 2021 Nextcloud GmbH
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package com.nextcloud.sso
|
||||||
|
|
||||||
|
import com.nextcloud.android.sso.InputStreamBinder
|
||||||
|
import junit.framework.Assert.assertEquals
|
||||||
|
import org.junit.Test
|
||||||
|
|
||||||
|
class InputStreamBinderTest {
|
||||||
|
@Test
|
||||||
|
fun convertMapToNVP() {
|
||||||
|
val source = mutableMapOf<String, String>()
|
||||||
|
source["quality"] = "1024p"
|
||||||
|
source["someOtherParameter"] = "parameterValue"
|
||||||
|
source["duplicate"] = "1"
|
||||||
|
source["duplicate"] = "2" // this overwrites previous parameter
|
||||||
|
|
||||||
|
val output = InputStreamBinder.convertMapToNVP(source)
|
||||||
|
|
||||||
|
assertEquals(source.size, output.size)
|
||||||
|
assertEquals("1024p", output[0].value)
|
||||||
|
assertEquals("parameterValue", output[1].value)
|
||||||
|
assertEquals("2", output[2].value)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun convertListToNVP() {
|
||||||
|
val source = mutableListOf<android.util.Pair<String, String>>()
|
||||||
|
source.add(android.util.Pair("quality", "1024p"))
|
||||||
|
source.add(android.util.Pair("someOtherParameter", "parameterValue"))
|
||||||
|
source.add(android.util.Pair("duplicate", "1"))
|
||||||
|
source.add(android.util.Pair("duplicate", "2")) // here we can have same parameter multiple times
|
||||||
|
|
||||||
|
val output = InputStreamBinder.convertListToNVP(source)
|
||||||
|
|
||||||
|
assertEquals(source.size, output.size)
|
||||||
|
assertEquals("1024p", output[0].value)
|
||||||
|
assertEquals("parameterValue", output[1].value)
|
||||||
|
assertEquals("1", output[2].value)
|
||||||
|
assertEquals("2", output[3].value)
|
||||||
|
}
|
||||||
|
}
|
|
@ -70,9 +70,12 @@ import java.io.InputStreamReader;
|
||||||
import java.io.ObjectInputStream;
|
import java.io.ObjectInputStream;
|
||||||
import java.io.ObjectOutputStream;
|
import java.io.ObjectOutputStream;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import androidx.annotation.VisibleForTesting;
|
||||||
|
|
||||||
import static com.nextcloud.android.sso.Constants.DELIMITER;
|
import static com.nextcloud.android.sso.Constants.DELIMITER;
|
||||||
import static com.nextcloud.android.sso.Constants.EXCEPTION_ACCOUNT_NOT_FOUND;
|
import static com.nextcloud.android.sso.Constants.EXCEPTION_ACCOUNT_NOT_FOUND;
|
||||||
import static com.nextcloud.android.sso.Constants.EXCEPTION_HTTP_REQUEST_FAILED;
|
import static com.nextcloud.android.sso.Constants.EXCEPTION_HTTP_REQUEST_FAILED;
|
||||||
|
@ -331,7 +334,11 @@ public class InputStreamBinder extends IInputStreamService.Stub {
|
||||||
|
|
||||||
HttpMethodBase method = buildMethod(request, client.getBaseUri(), requestBodyInputStream);
|
HttpMethodBase method = buildMethod(request, client.getBaseUri(), requestBodyInputStream);
|
||||||
|
|
||||||
method.setQueryString(convertMapToNVP(request.getParameter()));
|
if (request.getParameterV2() != null && !request.getParameterV2().isEmpty()) {
|
||||||
|
method.setQueryString(convertListToNVP(request.getParameterV2()));
|
||||||
|
} else {
|
||||||
|
method.setQueryString(convertMapToNVP(request.getParameter()));
|
||||||
|
}
|
||||||
method.addRequestHeader("OCS-APIREQUEST", "true");
|
method.addRequestHeader("OCS-APIREQUEST", "true");
|
||||||
|
|
||||||
for (Map.Entry<String, List<String>> header : request.getHeader().entrySet()) {
|
for (Map.Entry<String, List<String>> header : request.getHeader().entrySet()) {
|
||||||
|
@ -394,7 +401,12 @@ public class InputStreamBinder extends IInputStreamService.Stub {
|
||||||
|
|
||||||
HttpMethodBase method = buildMethod(request, client.getBaseUri(), requestBodyInputStream);
|
HttpMethodBase method = buildMethod(request, client.getBaseUri(), requestBodyInputStream);
|
||||||
|
|
||||||
method.setQueryString(convertMapToNVP(request.getParameter()));
|
if (request.getParameterV2() != null && !request.getParameterV2().isEmpty()) {
|
||||||
|
method.setQueryString(convertListToNVP(request.getParameterV2()));
|
||||||
|
} else {
|
||||||
|
method.setQueryString(convertMapToNVP(request.getParameter()));
|
||||||
|
}
|
||||||
|
|
||||||
method.addRequestHeader("OCS-APIREQUEST", "true");
|
method.addRequestHeader("OCS-APIREQUEST", "true");
|
||||||
|
|
||||||
for (Map.Entry<String, List<String>> header : request.getHeader().entrySet()) {
|
for (Map.Entry<String, List<String>> header : request.getHeader().entrySet()) {
|
||||||
|
@ -482,7 +494,8 @@ public class InputStreamBinder extends IInputStreamService.Stub {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static NameValuePair[] convertMapToNVP(Map<String, String> map) {
|
@VisibleForTesting
|
||||||
|
public static NameValuePair[] convertMapToNVP(Map<String, String> map) {
|
||||||
NameValuePair[] nvp = new NameValuePair[map.size()];
|
NameValuePair[] nvp = new NameValuePair[map.size()];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (String key : map.keySet()) {
|
for (String key : map.keySet()) {
|
||||||
|
@ -491,4 +504,15 @@ public class InputStreamBinder extends IInputStreamService.Stub {
|
||||||
}
|
}
|
||||||
return nvp;
|
return nvp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
public static NameValuePair[] convertListToNVP(Collection<QueryParam> list) {
|
||||||
|
NameValuePair[] nvp = new NameValuePair[list.size()];
|
||||||
|
int i = 0;
|
||||||
|
for (QueryParam pair : list) {
|
||||||
|
nvp[i] = new NameValuePair(pair.key, pair.value);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
return nvp;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
35
src/main/java/com/nextcloud/android/sso/QueryParam.java
Normal file
35
src/main/java/com/nextcloud/android/sso/QueryParam.java
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* Nextcloud Android client application
|
||||||
|
*
|
||||||
|
* @author Tobias Kaminsky
|
||||||
|
* Copyright (C) 2021 Tobias Kaminsky
|
||||||
|
* Copyright (C) 2021 Nextcloud GmbH
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.nextcloud.android.sso;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
public class QueryParam implements Serializable {
|
||||||
|
public String key;
|
||||||
|
public String value;
|
||||||
|
|
||||||
|
public QueryParam(String key, String value) {
|
||||||
|
this.key = key;
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,3 +1,25 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* Nextcloud Android client application
|
||||||
|
*
|
||||||
|
* @author Tobias Kaminsky
|
||||||
|
* Copyright (C) 2021 Tobias Kaminsky
|
||||||
|
* Copyright (C) 2021 Nextcloud GmbH
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Nextcloud SingleSignOn
|
* Nextcloud SingleSignOn
|
||||||
*
|
*
|
||||||
|
@ -19,8 +41,12 @@
|
||||||
|
|
||||||
package com.nextcloud.android.sso.aidl;
|
package com.nextcloud.android.sso.aidl;
|
||||||
|
|
||||||
|
import com.nextcloud.android.sso.QueryParam;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
@ -31,6 +57,7 @@ public class NextcloudRequest implements Serializable {
|
||||||
private String method;
|
private String method;
|
||||||
private Map<String, List<String>> header = new HashMap<>();
|
private Map<String, List<String>> header = new HashMap<>();
|
||||||
private Map<String, String> parameter = new HashMap<>();
|
private Map<String, String> parameter = new HashMap<>();
|
||||||
|
private final Collection<QueryParam> parameterV2 = new LinkedList<>();
|
||||||
private String requestBody;
|
private String requestBody;
|
||||||
private String url;
|
private String url;
|
||||||
private String token;
|
private String token;
|
||||||
|
@ -144,4 +171,8 @@ public class NextcloudRequest implements Serializable {
|
||||||
public boolean isFollowRedirects() {
|
public boolean isFollowRedirects() {
|
||||||
return this.followRedirects;
|
return this.followRedirects;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Collection<QueryParam> getParameterV2() {
|
||||||
|
return parameterV2;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue