diff --git a/app/src/main/java/foundation/e/drive/FileObservers/FileEventListener.java b/app/src/main/java/foundation/e/drive/FileObservers/FileEventListener.java index 4e2bbd2bdae100f94736f3ab2ae49be09559d862..c00b5a1b88d91e2686875ac19a1c999bdbb04486 100644 --- a/app/src/main/java/foundation/e/drive/FileObservers/FileEventListener.java +++ b/app/src/main/java/foundation/e/drive/FileObservers/FileEventListener.java @@ -105,10 +105,13 @@ public class FileEventListener { */ private void sendSyncRequestToSynchronizationService(@NonNull SyncRequest request) { Timber.d("Sending a SyncRequest for %s", request.getSyncedFileState().getName()); - if (serviceConnection.isBound()) { - serviceConnection.getSynchronizationService().queueSyncRequest(request); - serviceConnection.getSynchronizationService().startSynchronization(); - }else{ + + SynchronizationService service = serviceConnection.getSynchronizationService(); + + if (service != null) { + service.queueSyncRequest(request); + service.startSynchronization(); + } else { Timber.d("Impossible to send SyncRequest. FileEventListener is not bound to SynchronizationService"); } } diff --git a/app/src/main/java/foundation/e/drive/services/ObserverService.java b/app/src/main/java/foundation/e/drive/services/ObserverService.java index c1f084433c2950bd0eb8f7b80a8ac751fc5a91f5..e90718cccdab5d7ce71b347ecc0135da1c3695f8 100644 --- a/app/src/main/java/foundation/e/drive/services/ObserverService.java +++ b/app/src/main/java/foundation/e/drive/services/ObserverService.java @@ -179,8 +179,10 @@ public class ObserverService extends Service implements OnRemoteOperationListene return false; } - final boolean isSyncServicePaused = synchronizationServiceConnection.isBound() - && synchronizationServiceConnection.getSynchronizationService().pauseSync(); + final SynchronizationService service = + synchronizationServiceConnection.getSynchronizationService(); + + final boolean isSyncServicePaused = service != null && service.pauseSync(); Timber.d("isSyncServicePaused ? %s", isSyncServicePaused); return isSyncServicePaused; } @@ -329,8 +331,9 @@ public class ObserverService extends Service implements OnRemoteOperationListene startScan(false); - if (synchronizationServiceConnection.isBound()) { - synchronizationServiceConnection.getSynchronizationService().unPauseSync(); + SynchronizationService service = synchronizationServiceConnection.getSynchronizationService(); + if (service != null) { + service.unPauseSync(); } if (!syncRequests.isEmpty()) { @@ -352,9 +355,10 @@ public class ObserverService extends Service implements OnRemoteOperationListene * Send all gathered SyncRequest to SynchronizationService */ private void passSyncRequestsToSynchronizationService() { - if (synchronizationServiceConnection.isBound()) { - synchronizationServiceConnection.getSynchronizationService().queueSyncRequests(syncRequests.values()); - synchronizationServiceConnection.getSynchronizationService().startSynchronization(); + SynchronizationService service = synchronizationServiceConnection.getSynchronizationService(); + if (service != null) { + service.queueSyncRequests(syncRequests.values()); + service.startSynchronization(); } else { Timber.e("ERROR: binding to SynchronizationService lost"); } diff --git a/app/src/main/java/foundation/e/drive/utils/SynchronizationServiceConnection.java b/app/src/main/java/foundation/e/drive/utils/SynchronizationServiceConnection.java index 7640135a8fe6d54e1b56949c9c8195501f93b788..1227e96c3352f6af23fd83f43ea54cbae177c4d6 100644 --- a/app/src/main/java/foundation/e/drive/utils/SynchronizationServiceConnection.java +++ b/app/src/main/java/foundation/e/drive/utils/SynchronizationServiceConnection.java @@ -25,8 +25,8 @@ import timber.log.Timber; */ public class SynchronizationServiceConnection implements ServiceConnection { - private SynchronizationService synchronizationService; - private boolean isBound = false; + @Nullable + private SynchronizationService synchronizationService = null; private boolean attemptingToBind = false; @Override @@ -34,7 +34,6 @@ public class SynchronizationServiceConnection implements ServiceConnection { Timber.tag(SynchronizationServiceConnection.class.getSimpleName()) .v("binding to SynchronizationService"); attemptingToBind = false; - isBound = true; final SynchronizationService.SynchronizationBinder binder = (SynchronizationService.SynchronizationBinder) iBinder; synchronizationService = binder.getService(); } @@ -43,11 +42,7 @@ public class SynchronizationServiceConnection implements ServiceConnection { public void onServiceDisconnected(@Nullable ComponentName componentName) { Timber.tag(SynchronizationServiceConnection.class.getSimpleName()) .v("onServiceDisconnected()"); - isBound = false; - } - - public boolean isBound() { - return isBound; + synchronizationService = null; } /** @@ -65,9 +60,9 @@ public class SynchronizationServiceConnection implements ServiceConnection { */ public void unBind(@NonNull Context context) { attemptingToBind = false; - if (isBound) { + if (synchronizationService != null) { context.unbindService(this); - isBound = false; + synchronizationService = null; } } diff --git a/app/src/main/res/values-is/strings.xml b/app/src/main/res/values-is/strings.xml index ad7ddac8a635d896bd1f3f9651d26f85dfa006b6..9834689e96262ff7e78441d115bb80ecbeea14ac 100644 --- a/app/src/main/res/values-is/strings.xml +++ b/app/src/main/res/values-is/strings.xml @@ -1,5 +1,5 @@ - + /e/ Drif Leyfa samstillingu skráa á gjaldskyldu neti Myndir og myndskeið @@ -19,8 +19,8 @@ •   afrit Fela samheiti + Samheiti samheiti - Samheiti Engin internettenging fannst, viðmótshlutinn mun uppfærast sjálfkrafa þegar virk internettenging kemst á Tilkynningarás eDrive Netskýið þitt er fullt.