summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorBjoern Schiessle <schiessle@owncloud.com>2015-05-20 14:29:20 +0200
committerBjoern Schiessle <schiessle@owncloud.com>2015-05-21 14:15:26 +0200
commit5a20edac8241590e1b21a8ad0abcd9d6af2f5112 (patch)
tree5bedf2c9225ff8f832b4718c168bed0eb2cf071f /lib
parentfb51880a4a5a2afb79b7aa1e9c041c300cf34e9c (diff)
downloadnextcloud-server-5a20edac8241590e1b21a8ad0abcd9d6af2f5112.tar.gz
nextcloud-server-5a20edac8241590e1b21a8ad0abcd9d6af2f5112.zip
test to simulate a non-seekable stream wrapper
Diffstat (limited to 'lib')
-rw-r--r--lib/private/files/stream/encryption.php24
1 files changed, 18 insertions, 6 deletions
diff --git a/lib/private/files/stream/encryption.php b/lib/private/files/stream/encryption.php
index 7c8e6d4de83..7394b84a5d3 100644
--- a/lib/private/files/stream/encryption.php
+++ b/lib/private/files/stream/encryption.php
@@ -130,6 +130,7 @@ class Encryption extends Wrapper {
* @param int $size
* @param int $unencryptedSize
* @param int $headerSize
+ * @param string $wrapper stream wrapper class
* @return resource
*
* @throws \BadMethodCallException
@@ -144,7 +145,8 @@ class Encryption extends Wrapper {
$mode,
$size,
$unencryptedSize,
- $headerSize) {
+ $headerSize,
+ $wrapper = 'OC\Files\Stream\Encryption') {
$context = stream_context_create(array(
'ocencryption' => array(
@@ -164,7 +166,7 @@ class Encryption extends Wrapper {
)
));
- return self::wrapSource($source, $mode, $context, 'ocencryption', 'OC\Files\Stream\Encryption');
+ return self::wrapSource($source, $mode, $context, 'ocencryption', $wrapper);
}
/**
@@ -309,7 +311,7 @@ class Encryption extends Wrapper {
// flush will start writing there when the position moves to another block
$positionInFile = (int)floor($this->position / $this->unencryptedBlockSize) *
$this->util->getBlockSize() + $this->headerSize;
- $resultFseek = parent::stream_seek($positionInFile);
+ $resultFseek = $this->parentStreamSeek($positionInFile);
// only allow writes on seekable streams, or at the end of the encrypted stream
if (!($this->readOnly) && ($resultFseek || $positionInFile === $this->size)) {
@@ -376,10 +378,10 @@ class Encryption extends Wrapper {
* $this->util->getBlockSize() + $this->headerSize;
$oldFilePosition = parent::stream_tell();
- if (parent::stream_seek($newFilePosition)) {
- parent::stream_seek($oldFilePosition);
+ if ($this->parentStreamSeek($newFilePosition)) {
+ $this->parentStreamSeek($oldFilePosition);
$this->flush();
- parent::stream_seek($newFilePosition);
+ $this->parentStreamSeek($newFilePosition);
$this->position = $newPosition;
$return = true;
}
@@ -456,4 +458,14 @@ class Encryption extends Wrapper {
parent::stream_read($this->headerSize);
}
+ /**
+ * call stream_seek() from parent class
+ *
+ * @param integer $position
+ * @return bool
+ */
+ protected function parentStreamSeek($position) {
+ return parent::stream_seek($position);
+ }
+
}