|
@@ -50,6 +50,12 @@ import com.owncloud.android.lib.resources.shares.OCShare;
|
|
|
import com.owncloud.android.lib.resources.shares.ShareType;
|
|
|
import com.owncloud.android.utils.FileStorageUtils;
|
|
|
|
|
|
+import java.io.FileInputStream;
|
|
|
+import java.io.FileOutputStream;
|
|
|
+import java.io.IOException;
|
|
|
+import java.io.InputStream;
|
|
|
+import java.io.OutputStream;
|
|
|
+
|
|
|
public class FileDataStorageManager {
|
|
|
|
|
|
public static final int ROOT_PARENT_ID = 0;
|
|
@@ -60,7 +66,7 @@ public class FileDataStorageManager {
|
|
|
|
|
|
private static String TAG = FileDataStorageManager.class.getSimpleName();
|
|
|
|
|
|
-
|
|
|
+
|
|
|
public FileDataStorageManager(Account account, ContentResolver cr) {
|
|
|
mContentProviderClient = null;
|
|
|
mContentResolver = cr;
|
|
@@ -73,7 +79,7 @@ public class FileDataStorageManager {
|
|
|
mAccount = account;
|
|
|
}
|
|
|
|
|
|
-
|
|
|
+
|
|
|
public void setAccount(Account account) {
|
|
|
mAccount = account;
|
|
|
}
|
|
@@ -97,7 +103,7 @@ public class FileDataStorageManager {
|
|
|
public ContentProviderClient getContentProviderClient() {
|
|
|
return mContentProviderClient;
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
|
|
|
public OCFile getFileByPath(String path) {
|
|
|
Cursor c = getCursorForValue(ProviderTableMeta.FILE_PATH, path);
|
|
@@ -141,7 +147,7 @@ public class FileDataStorageManager {
|
|
|
return fileExists(ProviderTableMeta.FILE_PATH, path);
|
|
|
}
|
|
|
|
|
|
-
|
|
|
+
|
|
|
public Vector<OCFile> getFolderContent(OCFile f/*, boolean onlyOnDevice*/) {
|
|
|
if (f != null && f.isFolder() && f.getFileId() != -1) {
|
|
|
// TODO Enable when "On Device" is recovered ?
|
|
@@ -151,7 +157,7 @@ public class FileDataStorageManager {
|
|
|
return new Vector<OCFile>();
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
|
|
|
public Vector<OCFile> getFolderImages(OCFile folder/*, boolean onlyOnDevice*/) {
|
|
|
Vector<OCFile> ret = new Vector<OCFile>();
|
|
@@ -183,7 +189,7 @@ public class FileDataStorageManager {
|
|
|
cv.put(ProviderTableMeta.FILE_CONTENT_TYPE, file.getMimetype());
|
|
|
cv.put(ProviderTableMeta.FILE_NAME, file.getFileName());
|
|
|
//if (file.getParentId() != DataStorageManager.ROOT_PARENT_ID)
|
|
|
- cv.put(ProviderTableMeta.FILE_PARENT, file.getParentId());
|
|
|
+ cv.put(ProviderTableMeta.FILE_PARENT, file.getParentId());
|
|
|
cv.put(ProviderTableMeta.FILE_PATH, file.getRemotePath());
|
|
|
if (!file.isFolder())
|
|
|
cv.put(ProviderTableMeta.FILE_STORAGE_PATH, file.getStoragePath());
|
|
@@ -215,12 +221,12 @@ public class FileDataStorageManager {
|
|
|
if (getContentResolver() != null) {
|
|
|
getContentResolver().update(ProviderTableMeta.CONTENT_URI, cv,
|
|
|
ProviderTableMeta._ID + "=?",
|
|
|
- new String[] { String.valueOf(file.getFileId()) });
|
|
|
+ new String[]{String.valueOf(file.getFileId())});
|
|
|
} else {
|
|
|
try {
|
|
|
getContentProviderClient().update(ProviderTableMeta.CONTENT_URI,
|
|
|
cv, ProviderTableMeta._ID + "=?",
|
|
|
- new String[] { String.valueOf(file.getFileId()) });
|
|
|
+ new String[]{String.valueOf(file.getFileId())});
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG,
|
|
|
"Fail to insert insert file to database "
|
|
@@ -246,7 +252,7 @@ public class FileDataStorageManager {
|
|
|
long new_id = Long.parseLong(result_uri.getPathSegments()
|
|
|
.get(1));
|
|
|
file.setFileId(new_id);
|
|
|
- }
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
// if (file.isFolder()) {
|
|
@@ -254,17 +260,17 @@ public class FileDataStorageManager {
|
|
|
// } else {
|
|
|
// updateFolderSize(file.getParentId());
|
|
|
// }
|
|
|
-
|
|
|
+
|
|
|
return overriden;
|
|
|
}
|
|
|
|
|
|
|
|
|
/**
|
|
|
* Inserts or updates the list of files contained in a given folder.
|
|
|
- *
|
|
|
+ * <p/>
|
|
|
* CALLER IS THE RESPONSIBLE FOR GRANTING RIGHT UPDATE OF INFORMATION, NOT THIS METHOD.
|
|
|
* HERE ONLY DATA CONSISTENCY SHOULD BE GRANTED
|
|
|
- *
|
|
|
+ *
|
|
|
* @param folder
|
|
|
* @param updatedFiles
|
|
|
* @param filesToRemove
|
|
@@ -314,9 +320,9 @@ public class FileDataStorageManager {
|
|
|
// updating an existing file
|
|
|
operations.add(ContentProviderOperation.newUpdate(ProviderTableMeta.CONTENT_URI).
|
|
|
withValues(cv).
|
|
|
- withSelection( ProviderTableMeta._ID + "=?",
|
|
|
- new String[] { String.valueOf(file.getFileId()) })
|
|
|
- .build());
|
|
|
+ withSelection(ProviderTableMeta._ID + "=?",
|
|
|
+ new String[]{String.valueOf(file.getFileId())})
|
|
|
+ .build());
|
|
|
|
|
|
} else {
|
|
|
// adding a new file
|
|
@@ -324,9 +330,9 @@ public class FileDataStorageManager {
|
|
|
withValues(cv).build());
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
// prepare operations to remove files in the given folder
|
|
|
- String where = ProviderTableMeta.FILE_ACCOUNT_OWNER + "=?" + " AND " +
|
|
|
+ String where = ProviderTableMeta.FILE_ACCOUNT_OWNER + "=?" + " AND " +
|
|
|
ProviderTableMeta.FILE_PATH + "=?";
|
|
|
String [] whereArgs = null;
|
|
|
for (OCFile file : filesToRemove) {
|
|
@@ -360,7 +366,7 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
// update metadata of folder
|
|
|
ContentValues cv = new ContentValues();
|
|
|
cv.put(ProviderTableMeta.FILE_MODIFIED, folder.getModificationTimestamp());
|
|
@@ -383,12 +389,12 @@ public class FileDataStorageManager {
|
|
|
cv.put(ProviderTableMeta.FILE_PUBLIC_LINK, folder.getPublicLink());
|
|
|
cv.put(ProviderTableMeta.FILE_PERMISSIONS, folder.getPermissions());
|
|
|
cv.put(ProviderTableMeta.FILE_REMOTE_ID, folder.getRemoteId());
|
|
|
-
|
|
|
+
|
|
|
operations.add(ContentProviderOperation.newUpdate(ProviderTableMeta.CONTENT_URI).
|
|
|
withValues(cv).
|
|
|
- withSelection( ProviderTableMeta._ID + "=?",
|
|
|
- new String[] { String.valueOf(folder.getFileId()) })
|
|
|
- .build());
|
|
|
+ withSelection(ProviderTableMeta._ID + "=?",
|
|
|
+ new String[]{String.valueOf(folder.getFileId())})
|
|
|
+ .build());
|
|
|
|
|
|
// apply operations in batch
|
|
|
ContentProviderResult[] results = null;
|
|
@@ -413,7 +419,7 @@ public class FileDataStorageManager {
|
|
|
long newId;
|
|
|
Iterator<OCFile> filesIt = updatedFiles.iterator();
|
|
|
OCFile file = null;
|
|
|
- for (int i=0; i<results.length; i++) {
|
|
|
+ for (int i = 0; i < results.length; i++) {
|
|
|
if (filesIt.hasNext()) {
|
|
|
file = filesIt.next();
|
|
|
} else {
|
|
@@ -428,9 +434,9 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
//updateFolderSize(folder.getFileId());
|
|
|
-
|
|
|
+
|
|
|
}
|
|
|
|
|
|
|
|
@@ -464,14 +470,14 @@ public class FileDataStorageManager {
|
|
|
// Log_OC.e(TAG, "not updating size for folder " + id);
|
|
|
// }
|
|
|
// }
|
|
|
-
|
|
|
+
|
|
|
|
|
|
public boolean removeFile(OCFile file, boolean removeDBData, boolean removeLocalCopy) {
|
|
|
boolean success = true;
|
|
|
if (file != null) {
|
|
|
if (file.isFolder()) {
|
|
|
success = removeFolder(file, removeDBData, removeLocalCopy);
|
|
|
-
|
|
|
+
|
|
|
} else {
|
|
|
if (removeDBData) {
|
|
|
Uri file_uri = ContentUris.withAppendedId(
|
|
@@ -491,7 +497,7 @@ public class FileDataStorageManager {
|
|
|
} else {
|
|
|
deleted = getContentResolver().delete(file_uri, where, whereArgs);
|
|
|
}
|
|
|
- success &= (deleted > 0);
|
|
|
+ success &= (deleted > 0);
|
|
|
}
|
|
|
String localPath = file.getStoragePath();
|
|
|
if (removeLocalCopy && file.isDown() && localPath != null && success) {
|
|
@@ -509,12 +515,12 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
return success;
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
|
|
|
public boolean removeFolder(OCFile folder, boolean removeDBData, boolean removeLocalContent) {
|
|
|
boolean success = true;
|
|
|
if (folder != null && folder.isFolder()) {
|
|
|
- if (removeDBData && folder.getFileId() != -1) {
|
|
|
+ if (removeDBData && folder.getFileId() != -1) {
|
|
|
success = removeFolderInDb(folder);
|
|
|
}
|
|
|
if (removeLocalContent && success) {
|
|
@@ -525,7 +531,7 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
|
|
|
private boolean removeFolderInDb(OCFile folder) {
|
|
|
- Uri folder_uri = Uri.withAppendedPath(ProviderTableMeta.CONTENT_URI_DIR, "" +
|
|
|
+ Uri folder_uri = Uri.withAppendedPath(ProviderTableMeta.CONTENT_URI_DIR, "" +
|
|
|
folder.getFileId()); // URI for recursive deletion
|
|
|
String where = ProviderTableMeta.FILE_ACCOUNT_OWNER + "=?" + " AND " +
|
|
|
ProviderTableMeta.FILE_PATH + "=?";
|
|
@@ -538,7 +544,7 @@ public class FileDataStorageManager {
|
|
|
e.printStackTrace();
|
|
|
}
|
|
|
} else {
|
|
|
- deleted = getContentResolver().delete(folder_uri, where, whereArgs);
|
|
|
+ deleted = getContentResolver().delete(folder_uri, where, whereArgs);
|
|
|
}
|
|
|
return deleted > 0;
|
|
|
}
|
|
@@ -597,54 +603,54 @@ public class FileDataStorageManager {
|
|
|
|
|
|
/**
|
|
|
* Updates database and file system for a file or folder that was moved to a different location.
|
|
|
- *
|
|
|
+ *
|
|
|
* TODO explore better (faster) implementations
|
|
|
* TODO throw exceptions up !
|
|
|
*/
|
|
|
public void moveLocalFile(OCFile file, String targetPath, String targetParentPath) {
|
|
|
|
|
|
if (file != null && file.fileExists() && !OCFile.ROOT_PATH.equals(file.getFileName())) {
|
|
|
-
|
|
|
+
|
|
|
OCFile targetParent = getFileByPath(targetParentPath);
|
|
|
if (targetParent == null) {
|
|
|
throw new IllegalStateException("Parent folder of the target path does not exist!!");
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
/// 1. get all the descendants of the moved element in a single QUERY
|
|
|
Cursor c = null;
|
|
|
if (getContentProviderClient() != null) {
|
|
|
try {
|
|
|
c = getContentProviderClient().query(
|
|
|
- ProviderTableMeta.CONTENT_URI,
|
|
|
- null,
|
|
|
- ProviderTableMeta.FILE_ACCOUNT_OWNER + "=? AND " +
|
|
|
- ProviderTableMeta.FILE_PATH + " LIKE ? ",
|
|
|
- new String[] {
|
|
|
- mAccount.name,
|
|
|
- file.getRemotePath() + "%"
|
|
|
- },
|
|
|
- ProviderTableMeta.FILE_PATH + " ASC "
|
|
|
+ ProviderTableMeta.CONTENT_URI,
|
|
|
+ null,
|
|
|
+ ProviderTableMeta.FILE_ACCOUNT_OWNER + "=? AND " +
|
|
|
+ ProviderTableMeta.FILE_PATH + " LIKE ? ",
|
|
|
+ new String[]{
|
|
|
+ mAccount.name,
|
|
|
+ file.getRemotePath() + "%"
|
|
|
+ },
|
|
|
+ ProviderTableMeta.FILE_PATH + " ASC "
|
|
|
);
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG, e.getMessage());
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
} else {
|
|
|
c = getContentResolver().query(
|
|
|
- ProviderTableMeta.CONTENT_URI,
|
|
|
- null,
|
|
|
- ProviderTableMeta.FILE_ACCOUNT_OWNER + "=? AND " +
|
|
|
- ProviderTableMeta.FILE_PATH + " LIKE ? ",
|
|
|
- new String[] {
|
|
|
- mAccount.name,
|
|
|
- file.getRemotePath() + "%"
|
|
|
- },
|
|
|
- ProviderTableMeta.FILE_PATH + " ASC "
|
|
|
+ ProviderTableMeta.CONTENT_URI,
|
|
|
+ null,
|
|
|
+ ProviderTableMeta.FILE_ACCOUNT_OWNER + "=? AND " +
|
|
|
+ ProviderTableMeta.FILE_PATH + " LIKE ? ",
|
|
|
+ new String[]{
|
|
|
+ mAccount.name,
|
|
|
+ file.getRemotePath() + "%"
|
|
|
+ },
|
|
|
+ ProviderTableMeta.FILE_PATH + " ASC "
|
|
|
);
|
|
|
}
|
|
|
|
|
|
/// 2. prepare a batch of update operations to change all the descendants
|
|
|
- ArrayList<ContentProviderOperation> operations =
|
|
|
+ ArrayList<ContentProviderOperation> operations =
|
|
|
new ArrayList<ContentProviderOperation>(c.getCount());
|
|
|
String defaultSavePath = FileStorageUtils.getSavePath(mAccount.name);
|
|
|
List<String> originalPathsToTriggerMediaScan = new ArrayList<String>();
|
|
@@ -656,13 +662,13 @@ public class FileDataStorageManager {
|
|
|
ContentValues cv = new ContentValues(); // keep construction in the loop
|
|
|
OCFile child = createFileInstance(c);
|
|
|
cv.put(
|
|
|
- ProviderTableMeta.FILE_PATH,
|
|
|
- targetPath + child.getRemotePath().substring(lengthOfOldPath)
|
|
|
+ ProviderTableMeta.FILE_PATH,
|
|
|
+ targetPath + child.getRemotePath().substring(lengthOfOldPath)
|
|
|
);
|
|
|
- if (child.getStoragePath() != null &&
|
|
|
+ if (child.getStoragePath() != null &&
|
|
|
child.getStoragePath().startsWith(defaultSavePath)) {
|
|
|
// update link to downloaded content - but local move is not done here!
|
|
|
- String targetLocalPath = defaultSavePath + targetPath +
|
|
|
+ String targetLocalPath = defaultSavePath + targetPath +
|
|
|
child.getStoragePath().substring(lengthOfOldStoragePath);
|
|
|
|
|
|
cv.put(ProviderTableMeta.FILE_STORAGE_PATH, targetLocalPath);
|
|
@@ -675,17 +681,17 @@ public class FileDataStorageManager {
|
|
|
cv.put(
|
|
|
ProviderTableMeta.FILE_PARENT,
|
|
|
targetParent.getFileId()
|
|
|
- );
|
|
|
+ );
|
|
|
}
|
|
|
operations.add(
|
|
|
- ContentProviderOperation.newUpdate(ProviderTableMeta.CONTENT_URI).
|
|
|
- withValues(cv).
|
|
|
- withSelection(
|
|
|
- ProviderTableMeta._ID + "=?",
|
|
|
- new String[] { String.valueOf(child.getFileId()) }
|
|
|
+ ContentProviderOperation.newUpdate(ProviderTableMeta.CONTENT_URI).
|
|
|
+ withValues(cv).
|
|
|
+ withSelection(
|
|
|
+ ProviderTableMeta._ID + "=?",
|
|
|
+ new String[]{String.valueOf(child.getFileId())}
|
|
|
)
|
|
|
- .build());
|
|
|
-
|
|
|
+ .build());
|
|
|
+
|
|
|
} while (c.moveToNext());
|
|
|
}
|
|
|
c.close();
|
|
@@ -730,9 +736,60 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
+ public void copyLocalFile(OCFile file, String targetPath) {
|
|
|
+
|
|
|
+ if (file != null && file.fileExists() && !OCFile.ROOT_PATH.equals(file.getFileName())) {
|
|
|
+ String localPath = FileStorageUtils.getDefaultSavePathFor(mAccount.name, file);
|
|
|
+ File localFile = new File(localPath);
|
|
|
+ boolean copied = false;
|
|
|
+ String defaultSavePath = FileStorageUtils.getSavePath(mAccount.name);
|
|
|
+ if (localFile.exists()) {
|
|
|
+ File targetFile = new File(defaultSavePath + targetPath);
|
|
|
+ File targetFolder = targetFile.getParentFile();
|
|
|
+ if (!targetFolder.exists()) {
|
|
|
+ targetFolder.mkdirs();
|
|
|
+ }
|
|
|
+ copied = copyFile(localFile, targetFile);
|
|
|
+ }
|
|
|
+ Log_OC.d(TAG, "Local file COPIED : " + copied);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ private static boolean copyFile(File src, File target) {
|
|
|
+ boolean ret = true;
|
|
|
+
|
|
|
+ InputStream in = null;
|
|
|
+ OutputStream out = null;
|
|
|
+
|
|
|
+ try {
|
|
|
+ in = new FileInputStream(src);
|
|
|
+ out = new FileOutputStream(target);
|
|
|
+ byte[] buf = new byte[1024];
|
|
|
+ int len;
|
|
|
+ while ((len = in.read(buf)) > 0) {
|
|
|
+ out.write(buf, 0, len);
|
|
|
+ }
|
|
|
+ } catch (IOException ex) {
|
|
|
+ ret = false;
|
|
|
+ } finally {
|
|
|
+ if (in != null) try {
|
|
|
+ in.close();
|
|
|
+ } catch (IOException e) {
|
|
|
+ e.printStackTrace(System.err);
|
|
|
+ }
|
|
|
+ if (out != null) try {
|
|
|
+ out.close();
|
|
|
+ } catch (IOException e) {
|
|
|
+ e.printStackTrace(System.err);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return ret;
|
|
|
+ }
|
|
|
+
|
|
|
|
|
|
private Vector<OCFile> getFolderContent(long parentId/*, boolean onlyOnDevice*/) {
|
|
|
|
|
@@ -745,17 +802,17 @@ public class FileDataStorageManager {
|
|
|
|
|
|
if (getContentProviderClient() != null) {
|
|
|
try {
|
|
|
- c = getContentProviderClient().query(req_uri, null,
|
|
|
- ProviderTableMeta.FILE_PARENT + "=?" ,
|
|
|
- new String[] { String.valueOf(parentId)}, null);
|
|
|
+ c = getContentProviderClient().query(req_uri, null,
|
|
|
+ ProviderTableMeta.FILE_PARENT + "=?",
|
|
|
+ new String[]{String.valueOf(parentId)}, null);
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG, e.getMessage());
|
|
|
return ret;
|
|
|
}
|
|
|
} else {
|
|
|
- c = getContentResolver().query(req_uri, null,
|
|
|
- ProviderTableMeta.FILE_PARENT + "=?" ,
|
|
|
- new String[] { String.valueOf(parentId)}, null);
|
|
|
+ c = getContentResolver().query(req_uri, null,
|
|
|
+ ProviderTableMeta.FILE_PARENT + "=?",
|
|
|
+ new String[]{String.valueOf(parentId)}, null);
|
|
|
}
|
|
|
|
|
|
if (c.moveToFirst()) {
|
|
@@ -774,8 +831,8 @@ public class FileDataStorageManager {
|
|
|
|
|
|
return ret;
|
|
|
}
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
private OCFile createRootDir() {
|
|
|
OCFile file = new OCFile(OCFile.ROOT_PATH);
|
|
|
file.setMimetype("DIR");
|
|
@@ -793,7 +850,7 @@ public class FileDataStorageManager {
|
|
|
cmp_key + "=? AND "
|
|
|
+ ProviderTableMeta.FILE_ACCOUNT_OWNER
|
|
|
+ "=?",
|
|
|
- new String[] { value, mAccount.name }, null);
|
|
|
+ new String[]{value, mAccount.name}, null);
|
|
|
} else {
|
|
|
try {
|
|
|
c = getContentProviderClient().query(
|
|
@@ -801,7 +858,7 @@ public class FileDataStorageManager {
|
|
|
null,
|
|
|
cmp_key + "=? AND "
|
|
|
+ ProviderTableMeta.FILE_ACCOUNT_OWNER + "=?",
|
|
|
- new String[] { value, mAccount.name }, null);
|
|
|
+ new String[]{value, mAccount.name}, null);
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG,
|
|
|
"Couldn't determine file existance, assuming non existance: "
|
|
@@ -823,14 +880,14 @@ public class FileDataStorageManager {
|
|
|
key + "=? AND "
|
|
|
+ ProviderTableMeta.FILE_ACCOUNT_OWNER
|
|
|
+ "=?",
|
|
|
- new String[] { value, mAccount.name }, null);
|
|
|
+ new String[]{value, mAccount.name}, null);
|
|
|
} else {
|
|
|
try {
|
|
|
c = getContentProviderClient().query(
|
|
|
ProviderTableMeta.CONTENT_URI,
|
|
|
null,
|
|
|
key + "=? AND " + ProviderTableMeta.FILE_ACCOUNT_OWNER
|
|
|
- + "=?", new String[] { value, mAccount.name },
|
|
|
+ + "=?", new String[]{value, mAccount.name},
|
|
|
null);
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG, "Could not get file details: " + e.getMessage());
|
|
@@ -839,7 +896,7 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
return c;
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
|
|
|
private OCFile createFileInstance(Cursor c) {
|
|
|
OCFile file = null;
|
|
@@ -893,10 +950,11 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
return file;
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
/**
|
|
|
* Returns if the file/folder is shared by link or not
|
|
|
- * @param path Path of the file/folder
|
|
|
+ *
|
|
|
+ * @param path Path of the file/folder
|
|
|
* @return
|
|
|
*/
|
|
|
public boolean isShareByLink(String path) {
|
|
@@ -908,10 +966,11 @@ public class FileDataStorageManager {
|
|
|
c.close();
|
|
|
return file.isShareByLink();
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
/**
|
|
|
* Returns the public link of the file/folder
|
|
|
- * @param path Path of the file/folder
|
|
|
+ *
|
|
|
+ * @param path Path of the file/folder
|
|
|
* @return
|
|
|
*/
|
|
|
public String getPublicLink(String path) {
|
|
@@ -923,8 +982,8 @@ public class FileDataStorageManager {
|
|
|
c.close();
|
|
|
return file.getPublicLink();
|
|
|
}
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
// Methods for Shares
|
|
|
public boolean saveShare(OCShare share) {
|
|
|
boolean overriden = false;
|
|
@@ -946,19 +1005,19 @@ public class FileDataStorageManager {
|
|
|
cv.put(ProviderTableMeta.OCSHARES_USER_ID, share.getUserId());
|
|
|
cv.put(ProviderTableMeta.OCSHARES_ID_REMOTE_SHARED, share.getIdRemoteShared());
|
|
|
cv.put(ProviderTableMeta.OCSHARES_ACCOUNT_OWNER, mAccount.name);
|
|
|
-
|
|
|
+
|
|
|
if (shareExists(share.getIdRemoteShared())) { // for renamed files
|
|
|
|
|
|
overriden = true;
|
|
|
if (getContentResolver() != null) {
|
|
|
getContentResolver().update(ProviderTableMeta.CONTENT_URI_SHARE, cv,
|
|
|
ProviderTableMeta.OCSHARES_ID_REMOTE_SHARED + "=?",
|
|
|
- new String[] { String.valueOf(share.getIdRemoteShared()) });
|
|
|
+ new String[]{String.valueOf(share.getIdRemoteShared())});
|
|
|
} else {
|
|
|
try {
|
|
|
getContentProviderClient().update(ProviderTableMeta.CONTENT_URI_SHARE,
|
|
|
cv, ProviderTableMeta.OCSHARES_ID_REMOTE_SHARED + "=?",
|
|
|
- new String[] { String.valueOf(share.getIdRemoteShared()) });
|
|
|
+ new String[]{String.valueOf(share.getIdRemoteShared())});
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG,
|
|
|
"Fail to insert insert file to database "
|
|
@@ -984,7 +1043,7 @@ public class FileDataStorageManager {
|
|
|
long new_id = Long.parseLong(result_uri.getPathSegments()
|
|
|
.get(1));
|
|
|
share.setId(new_id);
|
|
|
- }
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
return overriden;
|
|
@@ -1000,7 +1059,7 @@ public class FileDataStorageManager {
|
|
|
ProviderTableMeta.OCSHARES_PATH + "=? AND "
|
|
|
+ ProviderTableMeta.OCSHARES_SHARE_TYPE + "=? AND "
|
|
|
+ ProviderTableMeta.OCSHARES_ACCOUNT_OWNER + "=?",
|
|
|
- new String[] { path, Integer.toString(type.getValue()), mAccount.name },
|
|
|
+ new String[]{path, Integer.toString(type.getValue()), mAccount.name},
|
|
|
null);
|
|
|
} else {
|
|
|
try {
|
|
@@ -1010,7 +1069,7 @@ public class FileDataStorageManager {
|
|
|
ProviderTableMeta.OCSHARES_PATH + "=? AND "
|
|
|
+ ProviderTableMeta.OCSHARES_SHARE_TYPE + "=? AND "
|
|
|
+ ProviderTableMeta.OCSHARES_ACCOUNT_OWNER + "=?",
|
|
|
- new String[] { path, Integer.toString(type.getValue()), mAccount.name },
|
|
|
+ new String[]{path, Integer.toString(type.getValue()), mAccount.name},
|
|
|
null);
|
|
|
|
|
|
} catch (RemoteException e) {
|
|
@@ -1025,7 +1084,7 @@ public class FileDataStorageManager {
|
|
|
c.close();
|
|
|
return share;
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
private OCShare createShareInstance(Cursor c) {
|
|
|
OCShare share = null;
|
|
|
if (c != null) {
|
|
@@ -1066,7 +1125,7 @@ public class FileDataStorageManager {
|
|
|
cmp_key + "=? AND "
|
|
|
+ ProviderTableMeta.OCSHARES_ACCOUNT_OWNER
|
|
|
+ "=?",
|
|
|
- new String[] { value, mAccount.name }, null);
|
|
|
+ new String[]{value, mAccount.name}, null);
|
|
|
} else {
|
|
|
try {
|
|
|
c = getContentProviderClient().query(
|
|
@@ -1074,7 +1133,7 @@ public class FileDataStorageManager {
|
|
|
null,
|
|
|
cmp_key + "=? AND "
|
|
|
+ ProviderTableMeta.OCSHARES_ACCOUNT_OWNER + "=?",
|
|
|
- new String[] { value, mAccount.name }, null);
|
|
|
+ new String[]{value, mAccount.name}, null);
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG,
|
|
|
"Couldn't determine file existance, assuming non existance: "
|
|
@@ -1086,7 +1145,7 @@ public class FileDataStorageManager {
|
|
|
c.close();
|
|
|
return retval;
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
private boolean shareExists(long remoteId) {
|
|
|
return shareExists(ProviderTableMeta.OCSHARES_ID_REMOTE_SHARED, String.valueOf(remoteId));
|
|
|
}
|
|
@@ -1096,8 +1155,8 @@ public class FileDataStorageManager {
|
|
|
cv.put(ProviderTableMeta.FILE_SHARE_BY_LINK, false);
|
|
|
cv.put(ProviderTableMeta.FILE_PUBLIC_LINK, "");
|
|
|
String where = ProviderTableMeta.FILE_ACCOUNT_OWNER + "=?";
|
|
|
- String [] whereArgs = new String[]{mAccount.name};
|
|
|
-
|
|
|
+ String[] whereArgs = new String[]{mAccount.name};
|
|
|
+
|
|
|
if (getContentResolver() != null) {
|
|
|
getContentResolver().update(ProviderTableMeta.CONTENT_URI, cv, where, whereArgs);
|
|
|
|
|
@@ -1117,7 +1176,7 @@ public class FileDataStorageManager {
|
|
|
ContentValues cv = new ContentValues();
|
|
|
cv.put(ProviderTableMeta.FILE_SHARE_BY_LINK, false);
|
|
|
cv.put(ProviderTableMeta.FILE_PUBLIC_LINK, "");
|
|
|
- String where = ProviderTableMeta.FILE_ACCOUNT_OWNER + "=? AND " +
|
|
|
+ String where = ProviderTableMeta.FILE_ACCOUNT_OWNER + "=? AND " +
|
|
|
ProviderTableMeta.FILE_PARENT + "=?";
|
|
|
String [] whereArgs = new String[] { mAccount.name , String.valueOf(folder.getFileId()) };
|
|
|
|
|
@@ -1138,8 +1197,8 @@ public class FileDataStorageManager {
|
|
|
|
|
|
private void cleanShares() {
|
|
|
String where = ProviderTableMeta.OCSHARES_ACCOUNT_OWNER + "=?";
|
|
|
- String [] whereArgs = new String[]{mAccount.name};
|
|
|
-
|
|
|
+ String[] whereArgs = new String[]{mAccount.name};
|
|
|
+
|
|
|
if (getContentResolver() != null) {
|
|
|
getContentResolver().delete(ProviderTableMeta.CONTENT_URI_SHARE, where, whereArgs);
|
|
|
|
|
@@ -1154,7 +1213,7 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
public void saveShares(Collection<OCShare> shares) {
|
|
|
cleanShares();
|
|
|
if (shares != null) {
|
|
@@ -1203,7 +1262,7 @@ public class FileDataStorageManager {
|
|
|
);
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
// apply operations in batch
|
|
|
if (operations.size() > 0) {
|
|
|
@SuppressWarnings("unused")
|
|
@@ -1219,21 +1278,21 @@ public class FileDataStorageManager {
|
|
|
} else {
|
|
|
results = getContentProviderClient().applyBatch(operations);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
} catch (OperationApplicationException e) {
|
|
|
Log_OC.e(TAG, "Exception in batch of operations " + e.getMessage());
|
|
|
-
|
|
|
+
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG, "Exception in batch of operations " + e.getMessage());
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
public void updateSharedFiles(Collection<OCFile> sharedFiles) {
|
|
|
cleanSharedFiles();
|
|
|
-
|
|
|
+
|
|
|
if (sharedFiles != null) {
|
|
|
ArrayList<ContentProviderOperation> operations =
|
|
|
new ArrayList<ContentProviderOperation>(sharedFiles.size());
|
|
@@ -1297,7 +1356,7 @@ public class FileDataStorageManager {
|
|
|
);
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
// apply operations in batch
|
|
|
if (operations.size() > 0) {
|
|
|
@SuppressWarnings("unused")
|
|
@@ -1313,21 +1372,21 @@ public class FileDataStorageManager {
|
|
|
} else {
|
|
|
results = getContentProviderClient().applyBatch(operations);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
} catch (OperationApplicationException e) {
|
|
|
Log_OC.e(TAG, "Exception in batch of operations " + e.getMessage());
|
|
|
-
|
|
|
+
|
|
|
} catch (RemoteException e) {
|
|
|
Log_OC.e(TAG, "Exception in batch of operations " + e.getMessage());
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- public void removeShare(OCShare share){
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ public void removeShare(OCShare share) {
|
|
|
Uri share_uri = ProviderTableMeta.CONTENT_URI_SHARE;
|
|
|
- String where = ProviderTableMeta.OCSHARES_ACCOUNT_OWNER + "=?" + " AND " +
|
|
|
+ String where = ProviderTableMeta.OCSHARES_ACCOUNT_OWNER + "=?" + " AND " +
|
|
|
ProviderTableMeta.FILE_PATH + "=?";
|
|
|
String [] whereArgs = new String[]{mAccount.name, share.getPath()};
|
|
|
if (getContentProviderClient() != null) {
|
|
@@ -1337,10 +1396,10 @@ public class FileDataStorageManager {
|
|
|
e.printStackTrace();
|
|
|
}
|
|
|
} else {
|
|
|
- getContentResolver().delete(share_uri, where, whereArgs);
|
|
|
+ getContentResolver().delete(share_uri, where, whereArgs);
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
public void saveSharesDB(ArrayList<OCShare> shares) {
|
|
|
saveShares(shares);
|
|
|
|
|
@@ -1351,7 +1410,7 @@ public class FileDataStorageManager {
|
|
|
String path = share.getPath();
|
|
|
if (share.isFolder()) {
|
|
|
path = path + FileUtils.PATH_SEPARATOR;
|
|
|
- }
|
|
|
+ }
|
|
|
|
|
|
// Update OCFile with data from share: ShareByLink and publicLink
|
|
|
OCFile file = getFileByPath(path);
|
|
@@ -1360,18 +1419,18 @@ public class FileDataStorageManager {
|
|
|
file.setShareByLink(true);
|
|
|
sharedFiles.add(file);
|
|
|
}
|
|
|
- }
|
|
|
+ }
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
updateSharedFiles(sharedFiles);
|
|
|
}
|
|
|
|
|
|
-
|
|
|
+
|
|
|
public void saveSharesInFolder(ArrayList<OCShare> shares, OCFile folder) {
|
|
|
cleanSharedFilesInFolder(folder);
|
|
|
ArrayList<ContentProviderOperation> operations = new ArrayList<ContentProviderOperation>();
|
|
|
operations = prepareRemoveSharesInFolder(folder, operations);
|
|
|
-
|
|
|
+
|
|
|
if (shares != null) {
|
|
|
// prepare operations to insert or update files to save in the given folder
|
|
|
for (OCShare share : shares) {
|
|
@@ -1415,7 +1474,7 @@ public class FileDataStorageManager {
|
|
|
//}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
// apply operations in batch
|
|
|
if (operations.size() > 0) {
|
|
|
@SuppressWarnings("unused")
|
|
@@ -1437,13 +1496,13 @@ public class FileDataStorageManager {
|
|
|
}
|
|
|
}
|
|
|
//}
|
|
|
-
|
|
|
+
|
|
|
}
|
|
|
|
|
|
private ArrayList<ContentProviderOperation> prepareRemoveSharesInFolder(
|
|
|
OCFile folder, ArrayList<ContentProviderOperation> preparedOperations) {
|
|
|
if (folder != null) {
|
|
|
- String where = ProviderTableMeta.OCSHARES_PATH + "=?" + " AND "
|
|
|
+ String where = ProviderTableMeta.OCSHARES_PATH + "=?" + " AND "
|
|
|
+ ProviderTableMeta.OCSHARES_ACCOUNT_OWNER + "=?";
|
|
|
String [] whereArgs = new String[]{ "", mAccount.name };
|
|
|
|