From 19b620c8a7e18eb611b39856d7365a22c7d7e588 Mon Sep 17 00:00:00 2001 From: Jonathan Klee Date: Fri, 15 Dec 2023 11:43:03 +0100 Subject: [PATCH 1/2] refactor: rename WorkerUtils in WorkLauncher --- .../account/receivers/AccountAddedReceiver.kt | 4 +- .../account/setup/FinishSetupWorker.java | 11 +++--- .../receivers/BootCompletedReceiver.java | 6 +-- .../e/drive/receivers/DebugCmdReceiver.java | 4 +- .../e/drive/synchronization/SyncProxy.kt | 5 +-- .../work/{WorkerUtils.kt => WorkLauncher.kt} | 38 ++++++++++++------- 6 files changed, 39 insertions(+), 29 deletions(-) rename app/src/main/java/foundation/e/drive/work/{WorkerUtils.kt => WorkLauncher.kt} (72%) diff --git a/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt b/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt index 2d0eb8d9..bd09dd8c 100644 --- a/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt +++ b/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt @@ -21,7 +21,7 @@ import foundation.e.drive.utils.AppConstants import foundation.e.drive.utils.DavClientProvider import foundation.e.drive.utils.RootSyncedFolderProvider import foundation.e.drive.work.WorkRequestFactory.* -import foundation.e.drive.work.WorkerUtils +import foundation.e.drive.work.WorkLauncher import timber.log.Timber /** @@ -52,7 +52,7 @@ class AccountAddedReceiver() : BroadcastReceiver() { if (registerSetupWorkers(context)) { DavClientProvider.getInstance().cleanUp() - WorkerUtils.enqueuePeriodicUserInfoFetching(WorkManager.getInstance(context)) + WorkLauncher.getInstance(context).enqueuePeriodicUserInfoFetching(); } } diff --git a/app/src/main/java/foundation/e/drive/account/setup/FinishSetupWorker.java b/app/src/main/java/foundation/e/drive/account/setup/FinishSetupWorker.java index 3a847973..f1ed2985 100644 --- a/app/src/main/java/foundation/e/drive/account/setup/FinishSetupWorker.java +++ b/app/src/main/java/foundation/e/drive/account/setup/FinishSetupWorker.java @@ -15,12 +15,11 @@ import static foundation.e.drive.utils.AppConstants.SHARED_PREFERENCE_NAME; import android.content.Context; import androidx.annotation.NonNull; -import androidx.work.WorkManager; import androidx.work.Worker; import androidx.work.WorkerParameters; import foundation.e.drive.utils.AppConstants; -import foundation.e.drive.work.WorkerUtils; +import foundation.e.drive.work.WorkLauncher; import timber.log.Timber; /** @@ -60,9 +59,9 @@ public class FinishSetupWorker extends Worker { } private void enqueueWorkers(@NonNull final Context appContext) { - final WorkManager workManager = WorkManager.getInstance(appContext); - WorkerUtils.enqueueOneTimeAppListGenerator(workManager); - WorkerUtils.enqueueOneTimeFullScan(workManager, false); - WorkerUtils.enqueuePeriodicFullScan(workManager); + final WorkLauncher launcher = WorkLauncher.getInstance(appContext); + launcher.enqueueOneTimeAppListGenerator(); + launcher.enqueueOneTimeFullScan(false); + launcher.enqueuePeriodicFullScan(); } } \ No newline at end of file diff --git a/app/src/main/java/foundation/e/drive/receivers/BootCompletedReceiver.java b/app/src/main/java/foundation/e/drive/receivers/BootCompletedReceiver.java index ae1c037b..ab0a9c4a 100644 --- a/app/src/main/java/foundation/e/drive/receivers/BootCompletedReceiver.java +++ b/app/src/main/java/foundation/e/drive/receivers/BootCompletedReceiver.java @@ -23,7 +23,7 @@ import foundation.e.drive.database.DbHelper; import foundation.e.drive.synchronization.SyncProxy; import foundation.e.drive.utils.AppConstants; import foundation.e.drive.utils.CommonUtils; -import foundation.e.drive.work.WorkerUtils; +import foundation.e.drive.work.WorkLauncher; import timber.log.Timber; /** @@ -113,8 +113,8 @@ public class BootCompletedReceiver extends BroadcastReceiver { final WorkManager workManager= WorkManager.getInstance(context); workManager.cancelAllWork(); - WorkerUtils.enqueuePeriodicFullScan(workManager); - WorkerUtils.enqueuePeriodicUserInfoFetching(workManager); + WorkLauncher.getInstance(context).enqueuePeriodicFullScan(); + WorkLauncher.getInstance(context).enqueuePeriodicUserInfoFetching(); } } diff --git a/app/src/main/java/foundation/e/drive/receivers/DebugCmdReceiver.java b/app/src/main/java/foundation/e/drive/receivers/DebugCmdReceiver.java index 2235d838..412f0339 100644 --- a/app/src/main/java/foundation/e/drive/receivers/DebugCmdReceiver.java +++ b/app/src/main/java/foundation/e/drive/receivers/DebugCmdReceiver.java @@ -30,7 +30,7 @@ import foundation.e.drive.models.SyncedFolder; import foundation.e.drive.synchronization.SyncProxy; import foundation.e.drive.synchronization.SyncRequestCollector; import foundation.e.drive.utils.ReleaseTree; -import foundation.e.drive.work.WorkerUtils; +import foundation.e.drive.work.WorkLauncher; import timber.log.Timber; /** @@ -56,7 +56,7 @@ public class DebugCmdReceiver extends BroadcastReceiver { switch (intent.getAction()) { case ACTION_FORCE_SCAN: Timber.d("Force Sync intent received"); - WorkerUtils.enqueueOneTimeFullScan(workManager, true); + WorkLauncher.getInstance(context).enqueueOneTimeFullScan(true); break; case ACTION_DUMP_DATABASE: Timber.d("Dump database intent received"); diff --git a/app/src/main/java/foundation/e/drive/synchronization/SyncProxy.kt b/app/src/main/java/foundation/e/drive/synchronization/SyncProxy.kt index dbd8f5f6..2c676d08 100644 --- a/app/src/main/java/foundation/e/drive/synchronization/SyncProxy.kt +++ b/app/src/main/java/foundation/e/drive/synchronization/SyncProxy.kt @@ -9,12 +9,11 @@ package foundation.e.drive.synchronization import android.app.Application import android.content.Context -import androidx.work.WorkManager import foundation.e.drive.EdriveApplication import foundation.e.drive.database.FailedSyncPrefsManager import foundation.e.drive.models.SyncRequest import foundation.e.drive.models.SyncWrapper -import foundation.e.drive.work.WorkerUtils +import foundation.e.drive.work.WorkLauncher import timber.log.Timber import java.util.concurrent.ConcurrentHashMap import java.util.concurrent.ConcurrentLinkedQueue @@ -131,7 +130,7 @@ object SyncProxy: SyncRequestCollector, SyncManager { context.startRecursiveFileObserver() if (previousSyncState != SyncState.SYNCHRONIZING) { - WorkerUtils.enqueueOneTimeSync(WorkManager.getInstance(context)) + WorkLauncher.getInstance(context).enqueueOneTimeSync(); } } diff --git a/app/src/main/java/foundation/e/drive/work/WorkerUtils.kt b/app/src/main/java/foundation/e/drive/work/WorkLauncher.kt similarity index 72% rename from app/src/main/java/foundation/e/drive/work/WorkerUtils.kt rename to app/src/main/java/foundation/e/drive/work/WorkLauncher.kt index 0575de17..77e4133a 100644 --- a/app/src/main/java/foundation/e/drive/work/WorkerUtils.kt +++ b/app/src/main/java/foundation/e/drive/work/WorkLauncher.kt @@ -7,6 +7,7 @@ */ package foundation.e.drive.work +import android.content.Context import androidx.work.ExistingPeriodicWorkPolicy import androidx.work.ExistingWorkPolicy import androidx.work.WorkManager @@ -19,26 +20,39 @@ import foundation.e.drive.work.WorkRequestFactory.WorkType /** * @author Vincent Bourgmayer */ -object WorkerUtils { +class WorkLauncher private constructor(context: Context) { + private val workManager: WorkManager - @JvmStatic - fun enqueuePeriodicUserInfoFetching(workManager: WorkManager) { + init { + workManager = WorkManager.getInstance(context) + } + + companion object { + private var instance: WorkLauncher? = null + + @JvmStatic + fun getInstance(context: Context): WorkLauncher { + return instance ?: WorkLauncher(context.applicationContext) + } + } + + fun enqueuePeriodicUserInfoFetching() { val request = WorkRequestFactory.getPeriodicWorkRequest(WorkType.PERIODIC_USER_INFO) - workManager.enqueueUniquePeriodicWork(AccountUserInfoWorker.UNIQUE_WORK_NAME, + workManager.enqueueUniquePeriodicWork( + AccountUserInfoWorker.UNIQUE_WORK_NAME, ExistingPeriodicWorkPolicy.UPDATE, - request) + request + ) } - @JvmStatic - fun enqueuePeriodicFullScan(workManager: WorkManager) { + fun enqueuePeriodicFullScan() { val request = WorkRequestFactory.getPeriodicWorkRequest(WorkType.PERIODIC_SCAN) workManager.enqueueUniquePeriodicWork(PeriodicScanWorker.UNIQUE_WORK_NAME, ExistingPeriodicWorkPolicy.KEEP, request) } - @JvmStatic - fun enqueueOneTimeFullScan(workManager: WorkManager, isForced: Boolean) { + fun enqueueOneTimeFullScan(isForced: Boolean) { if (isForced) { val request = WorkRequestFactory.getOneTimeWorkRequest(WorkType.ONE_TIME_FORCED_FULL_SCAN, null) @@ -55,15 +69,13 @@ object WorkerUtils { request) } - @JvmStatic - fun enqueueOneTimeAppListGenerator(workManager: WorkManager) { + fun enqueueOneTimeAppListGenerator() { val request = WorkRequestFactory.getOneTimeWorkRequest(WorkType.ONE_TIME_APP_LIST, null) workManager.enqueue(request) } - @JvmStatic - fun enqueueOneTimeSync(workManager: WorkManager) { + fun enqueueOneTimeSync() { val request = WorkRequestFactory.getOneTimeWorkRequest(WorkType.ONE_TIME_SYNC, null) workManager.enqueueUniqueWork(SyncWorker.UNIQUE_WORK_NAME, ExistingWorkPolicy.KEEP, request) } -- GitLab From 48e81621934779b4c2948ced1f78062e65b448aa Mon Sep 17 00:00:00 2001 From: Fahim Salam Chowdhury Date: Wed, 10 Jan 2024 14:33:32 +0000 Subject: [PATCH 2/2] refactor : remove unwanted semicolon --- .../e/drive/account/receivers/AccountAddedReceiver.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt b/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt index bd09dd8c..62190ca9 100644 --- a/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt +++ b/app/src/main/java/foundation/e/drive/account/receivers/AccountAddedReceiver.kt @@ -52,7 +52,7 @@ class AccountAddedReceiver() : BroadcastReceiver() { if (registerSetupWorkers(context)) { DavClientProvider.getInstance().cleanUp() - WorkLauncher.getInstance(context).enqueuePeriodicUserInfoFetching(); + WorkLauncher.getInstance(context).enqueuePeriodicUserInfoFetching() } } -- GitLab