]> source.dussan.org Git - nextcloud-server.git/commitdiff
try to fix unencrypted file size if it doesn't look plausible
authorBjoern Schiessle <schiessle@owncloud.com>
Mon, 14 Oct 2013 14:34:14 +0000 (16:34 +0200)
committerBjoern Schiessle <schiessle@owncloud.com>
Tue, 22 Oct 2013 09:54:00 +0000 (11:54 +0200)
apps/files_encryption/lib/proxy.php

index 958286a29c1b0c6b2493e491fa88982115f6fd18..2a77632b0c3ef5ff8f0228d56345f847716f7871 100644 (file)
@@ -319,6 +319,16 @@ class Proxy extends \OC_FileProxy {
 
                $view = new \OC_FilesystemView('/');
 
+               $userId = \OCP\User::getUser();
+               $util = new Util($view, $userId);
+
+               // if encryption is no longer enabled or if the files aren't migrated yet
+               // we return the default file size
+               if(!\OCP\App::isEnabled('files_encryption') ||
+                               $util->getMigrationStatus() !== Util::MIGRATION_COMPLETED) {
+                       return $size;
+               }
+
                // if path is a folder do nothing
                if ($view->is_dir($path)) {
                        return $size;
@@ -340,6 +350,15 @@ class Proxy extends \OC_FileProxy {
 
                // if file is encrypted return real file size
                if (is_array($fileInfo) && $fileInfo['encrypted'] === true) {
+                       // try to fix unencrypted file size if it doesn't look plausible
+                       if ((int)$fileInfo['size'] > 0 && (int)$fileInfo['encrypted_size'] === 0) {
+                               $fixSize = $util->getFileSize($path);
+                               $fileInfo['unencrypted_size'] = $fixSize;
+                               // put file info if not .part file
+                               if (!Keymanager::isPartialFilePath($relativePath)) {
+                                       $view->putFileInfo($path, $fileInfo);
+                               }
+                       }
                        $size = $fileInfo['unencrypted_size'];
                } else {
                        // self healing if file was removed from file cache
@@ -347,8 +366,6 @@ class Proxy extends \OC_FileProxy {
                                $fileInfo = array();
                        }
 
-                       $userId = \OCP\User::getUser();
-                       $util = new Util($view, $userId);
                        $fixSize = $util->getFileSize($path);
                        if ($fixSize > 0) {
                                $size = $fixSize;