+
+ private void startSyncOperation() {
+ FileDataStorageManager storageManager = new FileDataStorageManager(mOCAccount, mContext.getContentResolver());
+ // a fresh object is needed; many things could have occurred to the file
+ // since it was registered to observe again, assuming that local files
+ // are linked to a remote file AT MOST, SOMETHING TO BE DONE;
+ OCFile file = storageManager.getFileByLocalPath(mPath);
+ SynchronizeFileOperation sfo = new SynchronizeFileOperation(file, null, mOCAccount, true, mContext);
+ RemoteOperationResult result = sfo.execute(storageManager, mContext);
+ if (result.getCode() == ResultCode.SYNC_CONFLICT) {
+ // ISSUE 5: if the user is not running the app (this is a service!),
+ // this can be very intrusive; a notification should be preferred
+ Intent i = new Intent(mContext, ConflictsResolveActivity.class);
+ i.setFlags(i.getFlags() | Intent.FLAG_ACTIVITY_NEW_TASK);
+ i.putExtra(ConflictsResolveActivity.EXTRA_FILE, file);
+ i.putExtra(ConflictsResolveActivity.EXTRA_ACCOUNT, mOCAccount);
+ mContext.startActivity(i);
+ }
+ // TODO save other errors in some point where the user can inspect them
+ // later;
+ // or maybe just toast them;
+ // or nothing, very strange fails
+ }
+
+ /**
+ * Check if the timestamp of last file modification in local is more current
+ * that the timestamp when setting observer to the file
+ *
+ * @return boolean: True if file is updated, False if not
+ */
+ private boolean isFileUpdated() {
+ Log_OC.d(TAG, "FileLastModified: " + mFileLastModified);
+ return (new File(mPath).lastModified() > mFileLastModified);
+ }