Fixed crash in first installation
[pub/Android/ownCloud.git] / src / com / owncloud / android / operations / GetSharedFilesOperation.java
index 43dff72..daa172b 100644 (file)
 
 package com.owncloud.android.operations;
 
 
 package com.owncloud.android.operations;
 
+import java.util.ArrayList;
+
+import com.owncloud.android.datamodel.FileDataStorageManager;
+import com.owncloud.android.datamodel.OCFile;
+import com.owncloud.android.datamodel.OCShare;
 import com.owncloud.android.oc_framework.network.webdav.WebdavClient;
 import com.owncloud.android.oc_framework.operations.RemoteOperation;
 import com.owncloud.android.oc_framework.operations.RemoteOperationResult;
 import com.owncloud.android.oc_framework.network.webdav.WebdavClient;
 import com.owncloud.android.oc_framework.operations.RemoteOperation;
 import com.owncloud.android.oc_framework.operations.RemoteOperationResult;
+import com.owncloud.android.oc_framework.operations.ShareRemoteFile;
+import com.owncloud.android.oc_framework.operations.ShareType;
 import com.owncloud.android.oc_framework.operations.remote.GetRemoteSharedFilesOperation;
 import com.owncloud.android.oc_framework.operations.remote.GetRemoteSharedFilesOperation;
+import com.owncloud.android.oc_framework.utils.FileUtils;
+import com.owncloud.android.utils.Log_OC;
 
 /**
  * Access to remote operation to get the share files/folders
 
 /**
  * Access to remote operation to get the share files/folders
@@ -30,11 +39,16 @@ import com.owncloud.android.oc_framework.operations.remote.GetRemoteSharedFilesO
  */
 
 public class GetSharedFilesOperation extends RemoteOperation {
  */
 
 public class GetSharedFilesOperation extends RemoteOperation {
+    
+    private static final String TAG = GetSharedFilesOperation.class.getSimpleName();
 
     private String mUrlServer;
 
     private String mUrlServer;
+    protected FileDataStorageManager mStorageManager;
+    
 
 
-    public GetSharedFilesOperation(String urlServer) {
+    public GetSharedFilesOperation(String urlServer, FileDataStorageManager storageManager) {
         mUrlServer = urlServer;
         mUrlServer = urlServer;
+        mStorageManager = storageManager;
     }
 
     @Override
     }
 
     @Override
@@ -45,12 +59,36 @@ public class GetSharedFilesOperation extends RemoteOperation {
         if (result.isSuccess()) {
             
             // Update DB with the response
         if (result.isSuccess()) {
             
             // Update DB with the response
-            
-        } else {
-            
+            ArrayList<ShareRemoteFile> shareRemoteFiles = operation.getSharedFiles();
+            Log_OC.d(TAG, "Share list size = " + shareRemoteFiles.size());
+            for (ShareRemoteFile remoteFile: shareRemoteFiles) {
+                OCShare shareFile = new OCShare(remoteFile);
+                saveShareFileInDB(shareFile);
+            }
         }
         
         return result;
     }
 
         }
         
         return result;
     }
 
+    private void saveShareFileInDB(OCShare shareFile) {
+        // Save share file
+        mStorageManager.saveShareFile(shareFile);
+        
+        // Get the path
+        String path = shareFile.getPath();
+        if (shareFile.isDirectory()) {
+            path = path + FileUtils.PATH_SEPARATOR;
+        }           
+            
+        // Update OCFile with data from share: ShareByLink  ¿and publicLink?
+        OCFile file = mStorageManager.getFileByPath(path);
+        if (file != null) {
+            if (shareFile.getShareType().equals(ShareType.PUBLIC_LINK)) {
+                file.setShareByLink(true);
+                mStorageManager.saveFile(file);
+            }
+        } 
+    }
+
+    
 }
 }