summaryrefslogtreecommitdiffstats
path: root/apps/files_encryption/lib
diff options
context:
space:
mode:
authorBjörn Schießle <bjoern@schiessle.org>2013-05-27 05:17:31 -0700
committerBjörn Schießle <bjoern@schiessle.org>2013-05-27 05:17:31 -0700
commit5e243b48bb51e94daa3ba32c9175945d579040c8 (patch)
tree61e9578593255860ec92845b81649f0e4fcf996d /apps/files_encryption/lib
parentd878926256be72a27658ee6e98728f9c9b4a4b66 (diff)
parent5ce4149e752564c58a6f0191d0426c333dfbc347 (diff)
downloadnextcloud-server-5e243b48bb51e94daa3ba32c9175945d579040c8.tar.gz
nextcloud-server-5e243b48bb51e94daa3ba32c9175945d579040c8.zip
Merge pull request #3481 from owncloud/firsttime_enc
fix first time encryption after app was enabled
Diffstat (limited to 'apps/files_encryption/lib')
-rw-r--r--apps/files_encryption/lib/util.php35
1 files changed, 12 insertions, 23 deletions
diff --git a/apps/files_encryption/lib/util.php b/apps/files_encryption/lib/util.php
index 2980aa94e0c..cac67d496e8 100644
--- a/apps/files_encryption/lib/util.php
+++ b/apps/files_encryption/lib/util.php
@@ -421,7 +421,7 @@ class Util
// If the file uses old
// encryption system
- } elseif ( Crypt::isLegacyEncryptedContent( $this->tail( $filePath, 3 ), $relPath ) ) {
+ } elseif ( Crypt::isLegacyEncryptedContent( $data, $relPath ) ) {
$found['legacy'][] = array( 'name' => $file, 'path' => $filePath );
@@ -672,39 +672,28 @@ class Util
$relPath = $plainFile['path'];
//relative to /data
- $rawPath = $this->userId . '/files/' . $plainFile['path'];
+ $rawPath = '/'.$this->userId . '/files/' . $plainFile['path'];
// Open plain file handle for binary reading
- $plainHandle1 = $this->view->fopen( $rawPath, 'rb' );
+ $plainHandle = $this->view->fopen( $rawPath, 'rb' );
- // 2nd handle for moving plain file - view->rename() doesn't work, this is a workaround
- $plainHandle2 = $this->view->fopen( $rawPath . '.plaintmp', 'wb' );
+ // Open enc file handle for binary writing, with same filename as original plain file
+ $encHandle = fopen( 'crypt://' . $relPath.'.tmp', 'wb' );
// Move plain file to a temporary location
- stream_copy_to_stream( $plainHandle1, $plainHandle2 );
-
- // Close access to original file
- // $this->view->fclose( $plainHandle1 ); // not implemented in view{}
- // Delete original plain file so we can rename enc file later
- $this->view->unlink( $rawPath );
+ $size = stream_copy_to_stream( $plainHandle, $encHandle );
- // Open enc file handle for binary writing, with same filename as original plain file
- $encHandle = fopen( 'crypt://' . $relPath, 'wb' );
+ fclose($encHandle);
- // Save data from plain stream to new encrypted file via enc stream
- // NOTE: Stream{} will be invoked for handling
- // the encryption, and should handle all keys
- // and their generation etc. automatically
- stream_copy_to_stream( $plainHandle2, $encHandle );
+ $fakeRoot = $this->view->getRoot();
+ $this->view->chroot('/'.$this->userId.'/files');
- // get file size
- $size = $this->view->filesize( $rawPath . '.plaintmp' );
+ $this->view->rename($relPath . '.tmp', $relPath);
- // Delete temporary plain copy of file
- $this->view->unlink( $rawPath . '.plaintmp' );
+ $this->view->chroot($fakeRoot);
// Add the file to the cache
- \OC\Files\Filesystem::putFileInfo( $plainFile['path'], array( 'encrypted' => true, 'size' => $size, 'unencrypted_size' => $size ) );
+ \OC\Files\Filesystem::putFileInfo( $relPath, array( 'encrypted' => true, 'size' => $size, 'unencrypted_size' => $size ) );
}
// Encrypt legacy encrypted files