Fix share with user/group when displayname!=username

This commit is contained in:
masensio 2015-10-29 10:44:35 +01:00 committed by David A. Velasco
parent c5ba47d4f2
commit 7b0ec3d3a6

View file

@ -38,6 +38,10 @@ import com.owncloud.android.authentication.AccountUtils;
import com.owncloud.android.lib.common.operations.RemoteOperationResult;
import com.owncloud.android.lib.common.utils.Log_OC;
import com.owncloud.android.lib.resources.shares.GetRemoteShareesOperation;
import com.owncloud.android.lib.resources.shares.ShareType;
import org.json.JSONException;
import org.json.JSONObject;
import java.util.ArrayList;
import java.util.Iterator;
@ -128,37 +132,45 @@ public class UsersAndGroupsSearchProvider extends ContentProvider {
userQuery, REQUESTED_PAGE, RESULTS_PER_PAGE
);
RemoteOperationResult result = searchRequest.execute(account, getContext());
List<Pair<String, Byte>> names = new ArrayList<Pair<String, Byte>>();
List<JSONObject> names = new ArrayList<JSONObject>();
if (result.isSuccess()) {
for (Object o : result.getData()) {
names.add((Pair<String, Byte>) o);
// Get JSonObjects from response
names.add((JSONObject) o);
}
}
/// convert the responses from the OC server to the expected format
if (names.size() > 0) {
response = new MatrixCursor(COLUMNS);
Iterator<Pair<String, Byte>> namesIt = names.iterator();
Iterator<JSONObject> namesIt = names.iterator();
int count = 0;
Pair<String, Byte> item;
JSONObject item;
String displayName;
Uri dataUri;
Uri userBaseUri = new Uri.Builder().scheme("content").authority(DATA_USER).build();
Uri groupBaseUri = new Uri.Builder().scheme("content").authority(DATA_GROUP).build();
while (namesIt.hasNext()) {
item = namesIt.next();
if (GetRemoteShareesOperation.GROUP_TYPE.equals(item.second)) {
displayName = getContext().getString(R.string.share_group_clarification, item.first);
dataUri = Uri.withAppendedPath(groupBaseUri, item.first);
} else {
displayName = item.first;
dataUri = Uri.withAppendedPath(userBaseUri, item.first);
try {
while (namesIt.hasNext()) {
item = namesIt.next();
String userName = item.getString(GetRemoteShareesOperation.PROPERTY_LABEL);
JSONObject value = item.getJSONObject(GetRemoteShareesOperation.NODE_VALUE);
byte type = (byte) value.getInt(GetRemoteShareesOperation.PROPERTY_SHARE_TYPE);
String shareWith = value.getString(GetRemoteShareesOperation.PROPERTY_SHARE_WITH);
if (GetRemoteShareesOperation.GROUP_TYPE.equals(type)) {
displayName = getContext().getString(R.string.share_group_clarification, userName);
dataUri = Uri.withAppendedPath(groupBaseUri, shareWith);
} else {
displayName = userName;
dataUri = Uri.withAppendedPath(userBaseUri, shareWith);
}
response.newRow()
.add(count++) // BaseColumns._ID
.add(displayName) // SearchManager.SUGGEST_COLUMN_TEXT_1
.add(dataUri);
}
response.newRow()
.add(count++) // BaseColumns._ID
.add(displayName) // SearchManager.SUGGEST_COLUMN_TEXT_1
.add(dataUri);
} catch (JSONException e) {
Log_OC.e(TAG, "Exception while parsing data of users/groups", e);
}
}