From 193a00099b6b55822e7caf20f6e027881d5a0614 Mon Sep 17 00:00:00 2001 From: vincent Bourgmayer Date: Tue, 22 Nov 2022 14:42:23 +0100 Subject: [PATCH 1/2] prevent loading of all syncedFileState on periodic job that could result in deletion --- .../foundation/e/drive/database/DbHelper.java | 6 +-- .../e/drive/database/SyncedFileStateDAO.java | 50 +++++++++++-------- 2 files changed, 31 insertions(+), 25 deletions(-) diff --git a/app/src/main/java/foundation/e/drive/database/DbHelper.java b/app/src/main/java/foundation/e/drive/database/DbHelper.java index 77a58421..f83a57fd 100644 --- a/app/src/main/java/foundation/e/drive/database/DbHelper.java +++ b/app/src/main/java/foundation/e/drive/database/DbHelper.java @@ -160,11 +160,11 @@ public final class DbHelper extends SQLiteOpenHelper { * @return empty list if DB opening failed, either return the list of SyncedFileState */ public static List getSyncedFileStatesByFolders(Context context, List ids) {//Connect to DB - SyncedFileStateDAO dao = openSyncedFileStateDAO(context, false); - if(dao == null){ + final SyncedFileStateDAO dao = openSyncedFileStateDAO(context, false); + if (dao == null) { return new ArrayList<>(); } - List result = dao.getBySyncedFolderID(ids); + final List result = dao.getBySyncedFolderIds(ids); dao.close(); return result; } diff --git a/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java b/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java index fffc4da0..b710a2b5 100644 --- a/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java +++ b/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java @@ -141,37 +141,43 @@ class SyncedFileStateDAO { } /** - * Fetch many SyncedFileState by its localPath - * @param syncedFolderids List of path to filter. Need to be directory path - * @return List List of SyncedFileState filtered on syncedFolder ID. + * Fetch every syncedFileState for subfile of directories identified by syncedFolder's id. + * + * @param syncedFolderids List of SyncedFolderIds + * @return List List of SyncedFileState filtered on syncedFolder ID. The result is an empty list + * if list of syncedFolderIds is null or empty */ - List getBySyncedFolderID(List syncedFolderids) { + List getBySyncedFolderIds(final List syncedFolderids) { + final List result = new ArrayList<>(); + if (syncedFolderids == null || syncedFolderids.isEmpty()) { + Log.e(TAG, "getBySyncedFolderIds with empty list as parameter"); + return result; + } + String query = "Select " - +SyncedFileStateContract._ID+", " - +FILE_NAME+", " - +LOCAL_PATH+", " - +REMOTE_PATH+", " - +LAST_ETAG+", " - +LOCAL_LAST_MODIFIED+", " + + SyncedFileStateContract._ID + ", " + + FILE_NAME+", " + + LOCAL_PATH+", " + + REMOTE_PATH+", " + + LAST_ETAG+", " + + LOCAL_LAST_MODIFIED+", " + SYNCEDFOLDER_ID+", " + IS_MEDIA_TYPE+", " + SCANNABLE - +" FROM " - +TABLE_NAME; - if (syncedFolderids.size() > 0) { - query+=" WHERE "; - - for (int i = -1, idsSize = syncedFolderids.size(); ++i < idsSize; ) { - query += SYNCEDFOLDER_ID + " = " + syncedFolderids.get(i); - if (i < idsSize - 1) { - query += " OR "; - } + + " FROM " + + TABLE_NAME + + " WHERE "; + + for (int i = -1, idsSize = syncedFolderids.size(); ++i < idsSize; ) { + query += SYNCEDFOLDER_ID + " = " + syncedFolderids.get(i); + if (i < idsSize - 1) { + query += " OR "; } } + Log.d(TAG+"_getBySyncedFolderID(...)", query); - Cursor cursor = mDB.rawQuery(query, null); + final Cursor cursor = mDB.rawQuery(query, null); cursor.moveToFirst(); - List result = new ArrayList<>(); while(!cursor.isAfterLast() ) { result.add( cursorToSyncedFileState(cursor) ); cursor.moveToNext(); -- GitLab From 5d603389fed47756fb9a092891134bf4076038c1 Mon Sep 17 00:00:00 2001 From: Sayantan Roychowdhury Date: Wed, 23 Nov 2022 13:25:42 +0000 Subject: [PATCH 2/2] Apply 1 suggestion(s) to 1 file(s) --- .../e/drive/database/SyncedFileStateDAO.java | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java b/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java index b710a2b5..1249eb20 100644 --- a/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java +++ b/app/src/main/java/foundation/e/drive/database/SyncedFileStateDAO.java @@ -156,11 +156,11 @@ class SyncedFileStateDAO { String query = "Select " + SyncedFileStateContract._ID + ", " - + FILE_NAME+", " - + LOCAL_PATH+", " - + REMOTE_PATH+", " - + LAST_ETAG+", " - + LOCAL_LAST_MODIFIED+", " + + FILE_NAME + ", " + + LOCAL_PATH + ", " + + REMOTE_PATH + ", " + + LAST_ETAG + ", " + + LOCAL_LAST_MODIFIED + ", " + SYNCEDFOLDER_ID+", " + IS_MEDIA_TYPE+", " + SCANNABLE -- GitLab