X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/9809c0d3db2a5fc876d966ba057f0ff25fce008a..359ede5fdd2d9c442fb868a562e75850ff611672:/src/com/owncloud/android/operations/RemoveFileOperation.java diff --git a/src/com/owncloud/android/operations/RemoveFileOperation.java b/src/com/owncloud/android/operations/RemoveFileOperation.java index 77c00f31..012ef237 100644 --- a/src/com/owncloud/android/operations/RemoveFileOperation.java +++ b/src/com/owncloud/android/operations/RemoveFileOperation.java @@ -1,5 +1,9 @@ -/* ownCloud Android client application - * Copyright (C) 2012-2013 ownCloud Inc. +/** + * ownCloud Android client application + * + * @author David A. Velasco + * @author masensio + * Copyright (C) 2015 ownCloud Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2, @@ -17,40 +21,38 @@ package com.owncloud.android.operations; -import com.owncloud.android.datamodel.FileDataStorageManager; +import com.owncloud.android.MainApp; import com.owncloud.android.datamodel.OCFile; -import com.owncloud.android.oc_framework.network.webdav.WebdavClient; -import com.owncloud.android.oc_framework.operations.RemoteOperation; -import com.owncloud.android.oc_framework.operations.RemoteOperationResult; -import com.owncloud.android.oc_framework.operations.RemoteOperationResult.ResultCode; -import com.owncloud.android.oc_framework.operations.remote.RemoveRemoteFileOperation; +import com.owncloud.android.lib.common.OwnCloudClient; +import com.owncloud.android.lib.common.operations.RemoteOperationResult; +import com.owncloud.android.lib.common.operations.RemoteOperationResult.ResultCode; +import com.owncloud.android.lib.resources.files.RemoveRemoteFileOperation; +import com.owncloud.android.operations.common.SyncOperation; /** * Remote operation performing the removal of a remote file or folder in the ownCloud server. - * - * @author David A. Velasco */ -public class RemoveFileOperation extends RemoteOperation { +public class RemoveFileOperation extends SyncOperation { // private static final String TAG = RemoveFileOperation.class.getSimpleName(); OCFile mFileToRemove; - boolean mDeleteLocalCopy; - FileDataStorageManager mDataStorageManager; + String mRemotePath; + boolean mOnlyLocalCopy; /** * Constructor * - * @param fileToRemove OCFile instance describing the remote file or folder to remove from the server - * @param deleteLocalCopy When 'true', and a local copy of the file exists, it is also removed. - * @param storageManager Reference to the local database corresponding to the account where the file is contained. + * @param remotePath RemotePath of the OCFile instance describing the remote file or + * folder to remove from the server + * @param onlyLocalCopy When 'true', and a local copy of the file exists, only this is + * removed. */ - public RemoveFileOperation(OCFile fileToRemove, boolean deleteLocalCopy, FileDataStorageManager storageManager) { - mFileToRemove = fileToRemove; - mDeleteLocalCopy = deleteLocalCopy; - mDataStorageManager = storageManager; + public RemoveFileOperation(String remotePath, boolean onlyLocalCopy) { + mRemotePath = remotePath; + mOnlyLocalCopy = onlyLocalCopy; } @@ -69,34 +71,30 @@ public class RemoveFileOperation extends RemoteOperation { * @param client Client object to communicate with the remote ownCloud server. */ @Override - protected RemoteOperationResult run(WebdavClient client) { + protected RemoteOperationResult run(OwnCloudClient client) { RemoteOperationResult result = null; - RemoveRemoteFileOperation operation = new RemoveRemoteFileOperation(mFileToRemove.getRemotePath()); - result = operation.execute(client); + mFileToRemove = getStorageManager().getFileByPath(mRemotePath); + + boolean localRemovalFailed = false; + if (!mOnlyLocalCopy) { + RemoveRemoteFileOperation operation = new RemoveRemoteFileOperation(mRemotePath); + result = operation.execute(client); + if (result.isSuccess() || result.getCode() == ResultCode.FILE_NOT_FOUND) { + localRemovalFailed = !(getStorageManager().removeFile(mFileToRemove, true, true)); + } + + } else { + localRemovalFailed = !(getStorageManager().removeFile(mFileToRemove, false, true)); + if (!localRemovalFailed) { + result = new RemoteOperationResult(ResultCode.OK); + } + } - if (result.isSuccess() || result.getCode() == ResultCode.FILE_NOT_FOUND) { - mDataStorageManager.removeFile(mFileToRemove, true, mDeleteLocalCopy); + if (localRemovalFailed) { + result = new RemoteOperationResult(ResultCode.LOCAL_STORAGE_NOT_REMOVED); } -// try { -// delete = new DeleteMethod(client.getBaseUri() + WebdavUtils.encodePath(mFileToRemove.getRemotePath())); -// int status = client.executeMethod(delete, REMOVE_READ_TIMEOUT, REMOVE_CONNECTION_TIMEOUT); -// if (delete.succeeded() || status == HttpStatus.SC_NOT_FOUND) { -// mDataStorageManager.removeFile(mFileToRemove, true, mDeleteLocalCopy); -// } -// delete.getResponseBodyAsString(); // exhaust the response, although not interesting -// result = new RemoteOperationResult((delete.succeeded() || status == HttpStatus.SC_NOT_FOUND), status, delete.getResponseHeaders()); -// Log_OC.i(TAG, "Remove " + mFileToRemove.getRemotePath() + ": " + result.getLogMessage()); -// -// } catch (Exception e) { -// result = new RemoteOperationResult(e); -// Log_OC.e(TAG, "Remove " + mFileToRemove.getRemotePath() + ": " + result.getLogMessage(), e); -// -// } finally { -// if (delete != null) -// delete.releaseConnection(); -// } return result; }