2 * ownCloud Android client application
5 * @author David A. Velasco
6 * Copyright (C) 2015 ownCloud Inc.
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2,
10 * as published by the Free Software Foundation.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
22 package com
.owncloud
.android
.operations
;
25 * Creates a new private share for a given file
29 import com
.owncloud
.android
.datamodel
.FileDataStorageManager
;
30 import com
.owncloud
.android
.datamodel
.OCFile
;
31 import com
.owncloud
.android
.lib
.common
.OwnCloudClient
;
32 import com
.owncloud
.android
.lib
.common
.operations
.RemoteOperationResult
;
33 import com
.owncloud
.android
.lib
.resources
.files
.FileUtils
;
34 import com
.owncloud
.android
.lib
.resources
.shares
.CreateRemoteShareOperation
;
35 import com
.owncloud
.android
.lib
.resources
.shares
.OCShare
;
36 import com
.owncloud
.android
.lib
.resources
.shares
.ShareType
;
37 import com
.owncloud
.android
.operations
.common
.SyncOperation
;
39 public class CreateShareWithShareeOperation
extends SyncOperation
{
41 protected FileDataStorageManager mStorageManager
;
44 private String mShareeName
;
45 private ShareType mShareType
;
50 * @param path Full path of the file/folder being shared.
51 * @param shareeName User or group name of the target sharee.
52 * @param shareType Type of share determines type of sharee; {@link ShareType#USER} and {@link ShareType#GROUP}
53 * are the only valid values for the moment.
55 public CreateShareWithShareeOperation(String path
, String shareeName
, ShareType shareType
) {
56 if (!ShareType
.USER
.equals(shareType
) && !ShareType
.GROUP
.equals(shareType
)) {
57 throw new IllegalArgumentException("Illegal share type " + shareType
);
60 mShareeName
= shareeName
;
61 mShareType
= shareType
;
65 protected RemoteOperationResult
run(OwnCloudClient client
) {
66 // Check if the share link already exists
69 RemoteOperation operation = new GetRemoteSharesForFileOperation(mPath, false, false);
70 RemoteOperationResult result = operation.execute(client);
71 if (!result.isSuccess() || result.getData().size() <= 0) {
74 CreateRemoteShareOperation operation
= new CreateRemoteShareOperation(
80 OCShare
.DEFAULT_PERMISSION
82 operation
.setGetShareDetails(true
);
83 RemoteOperationResult result
= operation
.execute(client
);
86 if (result
.isSuccess()) {
87 if (result
.getData().size() > 0) {
88 OCShare share
= (OCShare
) result
.getData().get(0);
96 public String
getPath() {
100 private void updateData(OCShare share
) {
101 // Update DB with the response
102 share
.setPath(mPath
);
103 share
.setIsFolder(mPath
.endsWith(FileUtils
.PATH_SEPARATOR
));
105 getStorageManager().saveShare(share
);
107 // Update OCFile with data from share: ShareByLink and publicLink
108 OCFile file
= getStorageManager().getFileByPath(mPath
);
110 file
.setShareWithSharee(true
); // TODO - this should be done by the FileContentProvider, as part of getStorageManager().saveShare(share)
111 getStorageManager().saveFile(file
);