SyncedFolderObserverService.java 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /**
  2. * Nextcloud Android client application
  3. *
  4. * @author Tobias Kaminsky
  5. * @author Andy Scherzinger
  6. * @author Mario Danic
  7. * Copyright (C) 2016 Tobias Kaminsky, Andy Scherzinger
  8. * Copyright (C) 2017 Mario Danic
  9. * <p>
  10. * This program is free software: you can redistribute it and/or modify
  11. * it under the terms of the GNU Affero General Public License as published by
  12. * the Free Software Foundation, either version 3 of the License, or
  13. * at your option) any later version.
  14. * <p>
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU Affero General Public License for more details.
  19. * <p>
  20. * You should have received a copy of the GNU Affero General Public License
  21. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. */
  23. package com.owncloud.android.services.observer;
  24. import android.app.Service;
  25. import android.content.Intent;
  26. import android.os.Binder;
  27. import android.os.IBinder;
  28. import com.owncloud.android.MainApp;
  29. import com.owncloud.android.datamodel.SyncedFolder;
  30. import com.owncloud.android.datamodel.SyncedFolderProvider;
  31. import com.owncloud.android.lib.common.utils.Log_OC;
  32. import com.owncloud.android.services.AdvancedFileAlterationListener;
  33. import org.apache.commons.io.monitor.FileAlterationMonitor;
  34. import org.apache.commons.io.monitor.FileAlterationObserver;
  35. import java.io.File;
  36. import java.io.FileFilter;
  37. public class SyncedFolderObserverService extends Service {
  38. private static final String TAG = "SyncedFolderObserverService";
  39. private static final int MONITOR_SCAN_INTERVAL = 1000;
  40. private final IBinder mBinder = new SyncedFolderObserverBinder();
  41. private FileAlterationMonitor monitor;
  42. private FileFilter fileFilter;
  43. @Override
  44. public void onCreate() {
  45. SyncedFolderProvider syncedFolderProvider = new SyncedFolderProvider(MainApp.getAppContext().
  46. getContentResolver());
  47. monitor = new FileAlterationMonitor(MONITOR_SCAN_INTERVAL);
  48. fileFilter = new FileFilter() {
  49. @Override
  50. public boolean accept(File pathname) {
  51. return !pathname.getName().startsWith(".") && !pathname.getName().endsWith(".tmp") &&
  52. !pathname.getName().endsWith(".temp") && !pathname.getName().endsWith(".thumbnail");
  53. }
  54. };
  55. for (SyncedFolder syncedFolder : syncedFolderProvider.getSyncedFolders()) {
  56. if (syncedFolder.isEnabled()) {
  57. AdvancedFileAlterationObserver observer = new AdvancedFileAlterationObserver(syncedFolder, fileFilter);
  58. try {
  59. observer.init();
  60. observer.addListener(new AdvancedFileAlterationListener(syncedFolder));
  61. monitor.addObserver(observer);
  62. } catch (Exception e) {
  63. Log_OC.d(TAG, "Failed getting an observer to intialize " + e);
  64. }
  65. }
  66. }
  67. try {
  68. monitor.start();
  69. } catch (Exception e) {
  70. Log_OC.d(TAG, "Something went very wrong at onStartCommand");
  71. }
  72. }
  73. @Override
  74. public void onDestroy() {
  75. super.onDestroy();
  76. for (FileAlterationObserver fileAlterationObserver : monitor.getObservers()) {
  77. AdvancedFileAlterationObserver advancedFileAlterationObserver = (AdvancedFileAlterationObserver)
  78. fileAlterationObserver;
  79. try {
  80. monitor.removeObserver(advancedFileAlterationObserver);
  81. advancedFileAlterationObserver.checkAndNotifyNow();
  82. advancedFileAlterationObserver.destroy();
  83. } catch (Exception e) {
  84. Log_OC.d(TAG, "Something went very wrong on trying to destroy observers");
  85. }
  86. }
  87. }
  88. @Override
  89. public int onStartCommand(Intent intent, int flags, int startId) {
  90. return Service.START_NOT_STICKY;
  91. }
  92. /**
  93. * Restart oberver if it is enabled
  94. * If syncedFolder exists already, use it, otherwise create new observer
  95. *
  96. * @param syncedFolder
  97. */
  98. public void restartObserver(SyncedFolder syncedFolder) {
  99. boolean found = false;
  100. AdvancedFileAlterationObserver advancedFileAlterationObserver;
  101. for (FileAlterationObserver fileAlterationObserver : monitor.getObservers()) {
  102. advancedFileAlterationObserver =
  103. (AdvancedFileAlterationObserver) fileAlterationObserver;
  104. if (advancedFileAlterationObserver.getSyncedFolderID() == syncedFolder.getId()) {
  105. monitor.removeObserver(fileAlterationObserver);
  106. advancedFileAlterationObserver.checkAndNotifyNow();
  107. try {
  108. advancedFileAlterationObserver.destroy();
  109. } catch (Exception e) {
  110. Log_OC.d(TAG, "Failed to destroy the observer in restart");
  111. }
  112. if (syncedFolder.isEnabled()) {
  113. try {
  114. advancedFileAlterationObserver = new AdvancedFileAlterationObserver(syncedFolder, fileFilter);
  115. advancedFileAlterationObserver.init();
  116. advancedFileAlterationObserver.addListener(new AdvancedFileAlterationListener(syncedFolder));
  117. monitor.addObserver(advancedFileAlterationObserver);
  118. } catch (Exception e) {
  119. Log_OC.d(TAG, "Failed getting an observer to intialize");
  120. }
  121. } else {
  122. monitor.removeObserver(fileAlterationObserver);
  123. }
  124. found = true;
  125. break;
  126. }
  127. }
  128. if (!found && syncedFolder.isEnabled()) {
  129. try {
  130. advancedFileAlterationObserver = new AdvancedFileAlterationObserver(syncedFolder, fileFilter);
  131. advancedFileAlterationObserver.init();
  132. advancedFileAlterationObserver.addListener(new AdvancedFileAlterationListener(syncedFolder));
  133. monitor.addObserver(advancedFileAlterationObserver);
  134. } catch (Exception e) {
  135. Log_OC.d(TAG, "Failed getting an observer to intialize");
  136. }
  137. }
  138. }
  139. @Override
  140. public IBinder onBind(Intent arg0) {
  141. return mBinder;
  142. }
  143. public class SyncedFolderObserverBinder extends Binder {
  144. public SyncedFolderObserverService getService() {
  145. return SyncedFolderObserverService.this;
  146. }
  147. }
  148. }