1
0
mirror of https://github.com/owncloud/android-library.git synced 2025-06-08 00:16:09 +00:00

Merge pull request #194 from owncloud/show_reshares

Show reshares
This commit is contained in:
David González Verdugo 2018-08-09 10:56:40 +02:00 committed by GitHub
commit 9ab1b40682
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 81 additions and 49 deletions

View File

@ -1,7 +1,8 @@
/* ownCloud Android Library is available under MIT license /* ownCloud Android Library is available under MIT license
* @author masensio * @author masensio
* @author David A. Velasco * @author David A. Velasco
* Copyright (C) 2016 ownCloud GmbH. * @author David González Verdugo
* Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -26,14 +27,16 @@
package com.owncloud.android.lib.resources.shares; package com.owncloud.android.lib.resources.shares;
import org.apache.commons.httpclient.HttpStatus; import android.net.Uri;
import org.apache.commons.httpclient.methods.PostMethod;
import com.owncloud.android.lib.common.OwnCloudClient; import com.owncloud.android.lib.common.OwnCloudClient;
import com.owncloud.android.lib.common.operations.RemoteOperation; import com.owncloud.android.lib.common.operations.RemoteOperation;
import com.owncloud.android.lib.common.operations.RemoteOperationResult; import com.owncloud.android.lib.common.operations.RemoteOperationResult;
import com.owncloud.android.lib.common.utils.Log_OC; import com.owncloud.android.lib.common.utils.Log_OC;
import org.apache.commons.httpclient.HttpStatus;
import org.apache.commons.httpclient.methods.PostMethod;
import java.text.DateFormat; import java.text.DateFormat;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.util.Calendar; import java.util.Calendar;
@ -187,14 +190,18 @@ public class CreateRemoteShareOperation extends RemoteOperation {
@Override @Override
protected RemoteOperationResult run(OwnCloudClient client) { protected RemoteOperationResult run(OwnCloudClient client) {
RemoteOperationResult result = null; RemoteOperationResult result;
int status = -1; int status;
PostMethod post = null; PostMethod post = null;
try { try {
Uri requestUri = client.getBaseUri();
Uri.Builder uriBuilder = requestUri.buildUpon();
uriBuilder.appendEncodedPath(ShareUtils.SHARING_API_PATH);
// Post Method // Post Method
post = new PostMethod(client.getBaseUri() + ShareUtils.SHARING_API_PATH); post = new PostMethod(uriBuilder.build().toString());
post.setRequestHeader("Content-Type", post.setRequestHeader("Content-Type",
"application/x-www-form-urlencoded; charset=utf-8"); // necessary for special characters "application/x-www-form-urlencoded; charset=utf-8"); // necessary for special characters

View File

@ -1,6 +1,7 @@
/* ownCloud Android Library is available under MIT license /* ownCloud Android Library is available under MIT license
* @author David A. Velasco * @author David A. Velasco
* Copyright (C) 2016 ownCloud GmbH. * @author David González Verdugo
* Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -25,6 +26,8 @@
package com.owncloud.android.lib.resources.shares; package com.owncloud.android.lib.resources.shares;
import android.net.Uri;
import com.owncloud.android.lib.common.OwnCloudClient; import com.owncloud.android.lib.common.OwnCloudClient;
import com.owncloud.android.lib.common.operations.RemoteOperation; import com.owncloud.android.lib.common.operations.RemoteOperation;
import com.owncloud.android.lib.common.operations.RemoteOperationResult; import com.owncloud.android.lib.common.operations.RemoteOperationResult;
@ -59,7 +62,12 @@ public class GetRemoteShareOperation extends RemoteOperation {
// Get the response // Get the response
try { try {
get = new GetMethod(client.getBaseUri() + ShareUtils.SHARING_API_PATH + "/" + Long.toString(mRemoteId)); Uri requestUri = client.getBaseUri();
Uri.Builder uriBuilder = requestUri.buildUpon();
uriBuilder.appendEncodedPath(ShareUtils.SHARING_API_PATH);
uriBuilder.appendEncodedPath(Long.toString(mRemoteId));
get = new GetMethod(uriBuilder.build().toString());
get.addRequestHeader(OCS_API_HEADER, OCS_API_HEADER_VALUE); get.addRequestHeader(OCS_API_HEADER, OCS_API_HEADER_VALUE);
status = client.executeMethod(get); status = client.executeMethod(get);

View File

@ -2,7 +2,8 @@
* *
* @author masensio * @author masensio
* @author David A. Velasco * @author David A. Velasco
* Copyright (C) 2016 ownCloud GmbH. * @author David González Verdugo
* Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -112,7 +113,7 @@ public class GetRemoteShareesOperation extends RemoteOperation{
@Override @Override
protected RemoteOperationResult run(OwnCloudClient client) { protected RemoteOperationResult run(OwnCloudClient client) {
RemoteOperationResult result = null; RemoteOperationResult result;
int status; int status;
GetMethod get = null; GetMethod get = null;

View File

@ -1,7 +1,8 @@
/* ownCloud Android Library is available under MIT license /* ownCloud Android Library is available under MIT license
* @author masensio * @author masensio
* @author David A. Velasco * @author David A. Velasco
* Copyright (C) 2016 ownCloud GmbH. * @author David González Verdugo
* Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -26,15 +27,17 @@
package com.owncloud.android.lib.resources.shares; package com.owncloud.android.lib.resources.shares;
import org.apache.commons.httpclient.HttpStatus; import android.net.Uri;
import org.apache.commons.httpclient.NameValuePair;
import org.apache.commons.httpclient.methods.GetMethod;
import com.owncloud.android.lib.common.OwnCloudClient; import com.owncloud.android.lib.common.OwnCloudClient;
import com.owncloud.android.lib.common.operations.RemoteOperation; import com.owncloud.android.lib.common.operations.RemoteOperation;
import com.owncloud.android.lib.common.operations.RemoteOperationResult; import com.owncloud.android.lib.common.operations.RemoteOperationResult;
import com.owncloud.android.lib.common.utils.Log_OC; import com.owncloud.android.lib.common.utils.Log_OC;
import org.apache.commons.httpclient.HttpStatus;
import org.apache.commons.httpclient.NameValuePair;
import org.apache.commons.httpclient.methods.GetMethod;
/** /**
* Provide a list shares for a specific file. * Provide a list shares for a specific file.
* The input is the full path of the desired file. * The input is the full path of the desired file.
@ -71,14 +74,18 @@ public class GetRemoteSharesForFileOperation extends RemoteOperation {
@Override @Override
protected RemoteOperationResult run(OwnCloudClient client) { protected RemoteOperationResult run(OwnCloudClient client) {
RemoteOperationResult result = null; RemoteOperationResult result;
int status = -1; int status;
GetMethod get = null; GetMethod get = null;
try { try {
Uri requestUri = client.getBaseUri();
Uri.Builder uriBuilder = requestUri.buildUpon();
uriBuilder.appendEncodedPath(ShareUtils.SHARING_API_PATH);
// Get Method // Get Method
get = new GetMethod(client.getBaseUri() + ShareUtils.SHARING_API_PATH); get = new GetMethod(uriBuilder.build().toString());
// Add Parameters to Get Method // Add Parameters to Get Method
get.setQueryString(new NameValuePair[]{ get.setQueryString(new NameValuePair[]{
@ -125,5 +132,4 @@ public class GetRemoteSharesForFileOperation extends RemoteOperation {
private boolean isSuccess(int status) { private boolean isSuccess(int status) {
return (status == HttpStatus.SC_OK); return (status == HttpStatus.SC_OK);
} }
} }

View File

@ -26,14 +26,16 @@
package com.owncloud.android.lib.resources.shares; package com.owncloud.android.lib.resources.shares;
import org.apache.commons.httpclient.HttpStatus; import android.net.Uri;
import org.apache.commons.httpclient.methods.GetMethod;
import com.owncloud.android.lib.common.OwnCloudClient; import com.owncloud.android.lib.common.OwnCloudClient;
import com.owncloud.android.lib.common.operations.RemoteOperation; import com.owncloud.android.lib.common.operations.RemoteOperation;
import com.owncloud.android.lib.common.operations.RemoteOperationResult; import com.owncloud.android.lib.common.operations.RemoteOperationResult;
import com.owncloud.android.lib.common.utils.Log_OC; import com.owncloud.android.lib.common.utils.Log_OC;
import org.apache.commons.httpclient.HttpStatus;
import org.apache.commons.httpclient.methods.GetMethod;
/** /**
* Get the data from the server about ALL the known shares owned by the requester. * Get the data from the server about ALL the known shares owned by the requester.
*/ */
@ -56,7 +58,11 @@ public class GetRemoteSharesOperation extends RemoteOperation {
// Get the response // Get the response
try { try {
get = new GetMethod(client.getBaseUri() + ShareUtils.SHARING_API_PATH); Uri requestUri = client.getBaseUri();
Uri.Builder uriBuilder = requestUri.buildUpon();
uriBuilder.appendEncodedPath(ShareUtils.SHARING_API_PATH);
get = new GetMethod(uriBuilder.build().toString());
get.addRequestHeader(OCS_API_HEADER, OCS_API_HEADER_VALUE); get.addRequestHeader(OCS_API_HEADER, OCS_API_HEADER_VALUE);
status = client.executeMethod(get); status = client.executeMethod(get);

View File

@ -1,7 +1,8 @@
/* ownCloud Android Library is available under MIT license /* ownCloud Android Library is available under MIT license
* @author masensio * @author masensio
* @author David A. Velasco * @author David A. Velasco
* Copyright (C) 2016 ownCloud GmbH. * @author David González Verdugo
* Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -26,14 +27,16 @@
package com.owncloud.android.lib.resources.shares; package com.owncloud.android.lib.resources.shares;
import org.apache.commons.httpclient.HttpStatus; import android.net.Uri;
import org.apache.jackrabbit.webdav.client.methods.DeleteMethod;
import com.owncloud.android.lib.common.OwnCloudClient; import com.owncloud.android.lib.common.OwnCloudClient;
import com.owncloud.android.lib.common.operations.RemoteOperation; import com.owncloud.android.lib.common.operations.RemoteOperation;
import com.owncloud.android.lib.common.operations.RemoteOperationResult; import com.owncloud.android.lib.common.operations.RemoteOperationResult;
import com.owncloud.android.lib.common.utils.Log_OC; import com.owncloud.android.lib.common.utils.Log_OC;
import org.apache.commons.httpclient.HttpStatus;
import org.apache.jackrabbit.webdav.client.methods.DeleteMethod;
/** /**
* Remove a share * Remove a share
*/ */
@ -57,14 +60,18 @@ public class RemoveRemoteShareOperation extends RemoteOperation {
@Override @Override
protected RemoteOperationResult run(OwnCloudClient client) { protected RemoteOperationResult run(OwnCloudClient client) {
RemoteOperationResult result = null; RemoteOperationResult result;
int status = -1; int status;
DeleteMethod delete = null; DeleteMethod delete = null;
try { try {
String id = "/" + String.valueOf(mRemoteShareId); Uri requestUri = client.getBaseUri();
delete = new DeleteMethod(client.getBaseUri() + ShareUtils.SHARING_API_PATH + id); Uri.Builder uriBuilder = requestUri.buildUpon();
uriBuilder.appendEncodedPath(ShareUtils.SHARING_API_PATH);
uriBuilder.appendEncodedPath(String.valueOf(mRemoteShareId));
delete = new DeleteMethod(uriBuilder.build().toString());
delete.addRequestHeader(OCS_API_HEADER, OCS_API_HEADER_VALUE); delete.addRequestHeader(OCS_API_HEADER, OCS_API_HEADER_VALUE);
@ -79,7 +86,7 @@ public class RemoveRemoteShareOperation extends RemoteOperation {
); );
result = parser.parse(response); result = parser.parse(response);
Log_OC.d(TAG, "Unshare " + id + ": " + result.getLogMessage()); Log_OC.d(TAG, "Unshare " + mRemoteShareId + ": " + result.getLogMessage());
} else { } else {
result = new RemoteOperationResult(false, delete); result = new RemoteOperationResult(false, delete);

View File

@ -1,6 +1,7 @@
/* ownCloud Android Library is available under MIT license /* ownCloud Android Library is available under MIT license
* @author David A. Velasco * @author David A. Velasco
* Copyright (C) 2016 ownCloud GmbH. * @author David González Verdugo
* Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -70,7 +71,7 @@ public class ShareToRemoteOperationResultParser {
return new RemoteOperationResult(RemoteOperationResult.ResultCode.WRONG_SERVER_RESPONSE); return new RemoteOperationResult(RemoteOperationResult.ResultCode.WRONG_SERVER_RESPONSE);
} }
RemoteOperationResult result = null; RemoteOperationResult result;
ArrayList<Object> resultData = new ArrayList<Object>(); ArrayList<Object> resultData = new ArrayList<Object>();
try { try {

View File

@ -1,5 +1,5 @@
/* ownCloud Android Library is available under MIT license /* ownCloud Android Library is available under MIT license
* Copyright (C) 2016 ownCloud GmbH. * Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -30,13 +30,14 @@ import com.owncloud.android.lib.resources.status.OwnCloudVersion;
* Contains Constants for Share Operation * Contains Constants for Share Operation
* *
* @author masensio * @author masensio
* @author David González Verdugo
* *
*/ */
public class ShareUtils { public class ShareUtils {
// OCS Route // OCS Route
public static final String SHARING_API_PATH ="/ocs/v1.php/apps/files_sharing/api/v1/shares"; public static final String SHARING_API_PATH ="ocs/v2.php/apps/files_sharing/api/v1/shares";
// String to build the link with the token of a share: // String to build the link with the token of a share:
public static final String SHARING_LINK_PATH_BEFORE_VERSION_8 = "/public.php?service=files&t="; public static final String SHARING_LINK_PATH_BEFORE_VERSION_8 = "/public.php?service=files&t=";
@ -49,5 +50,4 @@ public class ShareUtils {
return SHARING_LINK_PATH_BEFORE_VERSION_8; return SHARING_LINK_PATH_BEFORE_VERSION_8;
} }
} }
} }

View File

@ -1,5 +1,5 @@
/* ownCloud Android Library is available under MIT license /* ownCloud Android Library is available under MIT license
* Copyright (C) 2016 ownCloud GmbH. * Copyright (C) 2018 ownCloud GmbH.
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy * Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal * of this software and associated documentation files (the "Software"), to deal
@ -41,7 +41,7 @@ import com.owncloud.android.lib.resources.files.FileUtils;
/** /**
* Parser for Share API Response * Parser for Share API Response
* @author masensio * @author masensio
* * @author David González Verdugo
*/ */
public class ShareXMLParser { public class ShareXMLParser {
@ -82,7 +82,7 @@ public class ShareXMLParser {
private static final String TYPE_FOLDER = "folder"; private static final String TYPE_FOLDER = "folder";
private static final int SUCCESS = 100; private static final int SUCCESS = 200;
private static final int ERROR_WRONG_PARAMETER = 400; private static final int ERROR_WRONG_PARAMETER = 400;
private static final int ERROR_FORBIDDEN = 403; private static final int ERROR_FORBIDDEN = 403;
private static final int ERROR_NOT_FOUND = 404; private static final int ERROR_NOT_FOUND = 404;
@ -172,7 +172,7 @@ public class ShareXMLParser {
*/ */
private ArrayList<OCShare> readOCS (XmlPullParser parser) throws XmlPullParserException, private ArrayList<OCShare> readOCS (XmlPullParser parser) throws XmlPullParserException,
IOException { IOException {
ArrayList<OCShare> shares = new ArrayList<OCShare>(); ArrayList<OCShare> shares = new ArrayList<>();
parser.require(XmlPullParser.START_TAG, ns , NODE_OCS); parser.require(XmlPullParser.START_TAG, ns , NODE_OCS);
while (parser.next() != XmlPullParser.END_TAG) { while (parser.next() != XmlPullParser.END_TAG) {
if (parser.getEventType() != XmlPullParser.START_TAG) { if (parser.getEventType() != XmlPullParser.START_TAG) {
@ -190,8 +190,6 @@ public class ShareXMLParser {
} }
return shares; return shares;
} }
/** /**
@ -439,5 +437,4 @@ public class ShareXMLParser {
} }
} }
} }
} }

View File

@ -208,7 +208,7 @@ public class UpdateRemoteShareOperation extends RemoteOperation {
try { try {
Uri requestUri = client.getBaseUri(); Uri requestUri = client.getBaseUri();
Uri.Builder uriBuilder = requestUri.buildUpon(); Uri.Builder uriBuilder = requestUri.buildUpon();
uriBuilder.appendEncodedPath(ShareUtils.SHARING_API_PATH.substring(1)); uriBuilder.appendEncodedPath(ShareUtils.SHARING_API_PATH);
uriBuilder.appendEncodedPath(Long.toString(mRemoteId)); uriBuilder.appendEncodedPath(Long.toString(mRemoteId));
uriString = uriBuilder.build().toString(); uriString = uriBuilder.build().toString();

View File

@ -50,7 +50,7 @@ public class GetRemoteCapabilitiesOperation extends RemoteOperation {
// OCS Routes // OCS Routes
private static final String OCS_ROUTE = "ocs/v1.php/cloud/capabilities"; private static final String OCS_ROUTE = "ocs/v2.php/cloud/capabilities";
// Arguments - names // Arguments - names
private static final String PARAM_FORMAT = "format"; private static final String PARAM_FORMAT = "format";

View File

@ -48,7 +48,7 @@ public class GetRemoteUserInfoOperation extends RemoteOperation {
private static final String TAG = GetRemoteUserInfoOperation.class.getSimpleName(); private static final String TAG = GetRemoteUserInfoOperation.class.getSimpleName();
// OCS Route // OCS Route
private static final String OCS_ROUTE = "/ocs/v1.php/cloud/user?format=json"; private static final String OCS_ROUTE = "/ocs/v2.php/cloud/user?format=json";
// JSON Node names // JSON Node names
private static final String NODE_OCS = "ocs"; private static final String NODE_OCS = "ocs";
@ -125,5 +125,4 @@ public class GetRemoteUserInfoOperation extends RemoteOperation {
public String mDisplayName = ""; public String mDisplayName = "";
public String mEmail = ""; public String mEmail = "";
} }
} }