summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBjörn Schießle <bjoern@schiessle.org>2013-11-15 08:47:22 -0800
committerBjörn Schießle <bjoern@schiessle.org>2013-11-15 08:47:22 -0800
commit3ad546002f11b4e252890fa65ea64d3fd9682b9d (patch)
tree9c555cd939f2eae43ade2b31616ecede23d52b33
parent6355af162cf1c68aaf00eaf1d19b8b5fba7e84a0 (diff)
parent2624a6cb328102c4029b91dcc7617fa953ac454d (diff)
downloadnextcloud-server-3ad546002f11b4e252890fa65ea64d3fd9682b9d.tar.gz
nextcloud-server-3ad546002f11b4e252890fa65ea64d3fd9682b9d.zip
Merge pull request #5833 from owncloud/encryption_fixes
[encryption] preserve timestamps and etags during encryption/decryption
-rw-r--r--apps/files_encryption/lib/stream.php25
-rw-r--r--apps/files_encryption/lib/util.php22
-rwxr-xr-xapps/files_encryption/tests/util.php58
3 files changed, 83 insertions, 22 deletions
diff --git a/apps/files_encryption/lib/stream.php b/apps/files_encryption/lib/stream.php
index 8c81bb82bef..fe85b2eac4a 100644
--- a/apps/files_encryption/lib/stream.php
+++ b/apps/files_encryption/lib/stream.php
@@ -67,6 +67,7 @@ class Stream {
* @var \OC\Files\View
*/
private $rootView; // a fsview object set to '/'
+
/**
* @var \OCA\Encryption\Session
*/
@@ -528,20 +529,22 @@ class Stream {
\OC_FileProxy::$enabled = $proxyStatus;
}
+ // we need to update the file info for the real file, not for the
+ // part file.
+ $path = Helper::stripPartialFileExtension($this->rawPath);
+
// get file info
- $fileInfo = $this->rootView->getFileInfo($this->rawPath);
- if (!is_array($fileInfo)) {
- $fileInfo = array();
+ $fileInfo = $this->rootView->getFileInfo($path);
+ if (is_array($fileInfo)) {
+ // set encryption data
+ $fileInfo['encrypted'] = true;
+ $fileInfo['size'] = $this->size;
+ $fileInfo['unencrypted_size'] = $this->unencryptedSize;
+
+ // set fileinfo
+ $this->rootView->putFileInfo($path, $fileInfo);
}
- // set encryption data
- $fileInfo['encrypted'] = true;
- $fileInfo['size'] = $this->size;
- $fileInfo['unencrypted_size'] = $this->unencryptedSize;
-
- // set fileinfo
- $this->rootView->putFileInfo($this->rawPath, $fileInfo);
-
}
return fclose($this->handle);
diff --git a/apps/files_encryption/lib/util.php b/apps/files_encryption/lib/util.php
index f099a36d0c0..1af5e56e10b 100644
--- a/apps/files_encryption/lib/util.php
+++ b/apps/files_encryption/lib/util.php
@@ -717,17 +717,17 @@ class Util {
// Encrypt unencrypted files
foreach ($found['encrypted'] as $encryptedFile) {
- //get file info
- $fileInfo = \OC\Files\Filesystem::getFileInfo($encryptedFile['path']);
-
//relative to data/<user>/file
$relPath = Helper::stripUserFilesPath($encryptedFile['path']);
+ //get file info
+ $fileInfo = \OC\Files\Filesystem::getFileInfo($relPath);
+
//relative to /data
$rawPath = $encryptedFile['path'];
//get timestamp
- $timestamp = $this->view->filemtime($rawPath);
+ $timestamp = $fileInfo['mtime'];
//enable proxy to use OC\Files\View to access the original file
\OC_FileProxy::$enabled = true;
@@ -768,10 +768,10 @@ class Util {
$this->view->rename($relPath . '.part', $relPath);
- $this->view->chroot($fakeRoot);
-
//set timestamp
- $this->view->touch($rawPath, $timestamp);
+ $this->view->touch($relPath, $timestamp);
+
+ $this->view->chroot($fakeRoot);
// Add the file to the cache
\OC\Files\Filesystem::putFileInfo($relPath, array(
@@ -839,7 +839,7 @@ class Util {
$rawPath = '/' . $this->userId . '/files/' . $plainFile['path'];
// keep timestamp
- $timestamp = $this->view->filemtime($rawPath);
+ $timestamp = $fileInfo['mtime'];
// Open plain file handle for binary reading
$plainHandle = $this->view->fopen($rawPath, 'rb');
@@ -858,10 +858,10 @@ class Util {
$this->view->rename($relPath . '.part', $relPath);
- $this->view->chroot($fakeRoot);
-
// set timestamp
- $this->view->touch($rawPath, $timestamp);
+ $this->view->touch($relPath, $timestamp);
+
+ $this->view->chroot($fakeRoot);
// Add the file to the cache
\OC\Files\Filesystem::putFileInfo($relPath, array(
diff --git a/apps/files_encryption/tests/util.php b/apps/files_encryption/tests/util.php
index 1b93bc36c8e..e8dfb74f3f3 100755
--- a/apps/files_encryption/tests/util.php
+++ b/apps/files_encryption/tests/util.php
@@ -281,6 +281,64 @@ class Test_Encryption_Util extends \PHPUnit_Framework_TestCase {
$this->assertFalse($this->util->isSharedPath($path));
}
+ function testEncryptAll() {
+
+ $filename = "/encryptAll" . time() . ".txt";
+ $util = new Encryption\Util($this->view, $this->userId);
+
+ // disable encryption to upload a unencrypted file
+ \OC_App::disable('files_encryption');
+
+ $this->view->file_put_contents($this->userId . '/files/' . $filename, $this->dataShort);
+
+ $fileInfoUnencrypted = $this->view->getFileInfo($this->userId . '/files/' . $filename);
+
+ $this->assertTrue(is_array($fileInfoUnencrypted));
+
+ // enable file encryption again
+ \OC_App::enable('files_encryption');
+
+ // encrypt all unencrypted files
+ $util->encryptAll('/' . $this->userId . '/' . 'files');
+
+ $fileInfoEncrypted = $this->view->getFileInfo($this->userId . '/files/' . $filename);
+
+ $this->assertTrue(is_array($fileInfoEncrypted));
+
+ // check if mtime and etags unchanged
+ $this->assertEquals($fileInfoEncrypted['mtime'], $fileInfoUnencrypted['mtime']);
+ $this->assertEquals($fileInfoEncrypted['etag'], $fileInfoUnencrypted['etag']);
+
+ $this->view->unlink($this->userId . '/files/' . $filename);
+ }
+
+
+ function testDecryptAll() {
+
+ $filename = "/decryptAll" . time() . ".txt";
+ $util = new Encryption\Util($this->view, $this->userId);
+
+ $this->view->file_put_contents($this->userId . '/files/' . $filename, $this->dataShort);
+
+ $fileInfoEncrypted = $this->view->getFileInfo($this->userId . '/files/' . $filename);
+
+ $this->assertTrue(is_array($fileInfoEncrypted));
+
+ // encrypt all unencrypted files
+ $util->decryptAll('/' . $this->userId . '/' . 'files');
+
+ $fileInfoUnencrypted = $this->view->getFileInfo($this->userId . '/files/' . $filename);
+
+ $this->assertTrue(is_array($fileInfoUnencrypted));
+
+ // check if mtime and etags unchanged
+ $this->assertEquals($fileInfoEncrypted['mtime'], $fileInfoUnencrypted['mtime']);
+ $this->assertEquals($fileInfoEncrypted['etag'], $fileInfoUnencrypted['etag']);
+
+ $this->view->unlink($this->userId . '/files/' . $filename);
+
+ }
+
/**
* @large
*/