Merge pull request #15980 from owncloud/jknockaert-patch-1
fix bug #15973
This commit is contained in:
commit
a1e60e7882
2 changed files with 18 additions and 19 deletions
|
@ -356,24 +356,22 @@ class Encryption extends Wrapper {
|
|||
|
||||
switch ($whence) {
|
||||
case SEEK_SET:
|
||||
if ($offset < $this->unencryptedSize && $offset >= 0) {
|
||||
$newPosition = $offset;
|
||||
}
|
||||
$newPosition = $offset;
|
||||
break;
|
||||
case SEEK_CUR:
|
||||
if ($offset >= 0) {
|
||||
$newPosition = $offset + $this->position;
|
||||
}
|
||||
$newPosition = $this->position + $offset;
|
||||
break;
|
||||
case SEEK_END:
|
||||
if ($this->unencryptedSize + $offset >= 0) {
|
||||
$newPosition = $this->unencryptedSize + $offset;
|
||||
}
|
||||
$newPosition = $this->unencryptedSize + $offset;
|
||||
break;
|
||||
default:
|
||||
return $return;
|
||||
}
|
||||
|
||||
if ($newPosition > $this->unencryptedSize || $newPosition < 0) {
|
||||
return $return;
|
||||
}
|
||||
|
||||
$newFilePosition = floor($newPosition / $this->unencryptedBlockSize)
|
||||
* $this->util->getBlockSize() + $this->headerSize;
|
||||
|
||||
|
|
|
@ -160,15 +160,6 @@ class Encryption extends \Test\TestCase {
|
|||
$this->assertEquals('foobar', fread($stream, 100));
|
||||
fclose($stream);
|
||||
|
||||
unlink($fileName);
|
||||
}
|
||||
|
||||
public function testWriteWriteRead() {
|
||||
$fileName = tempnam("/tmp", "FOO");
|
||||
$stream = $this->getStream($fileName, 'w+', 0);
|
||||
$this->assertEquals(6, fwrite($stream, 'foobar'));
|
||||
fclose($stream);
|
||||
|
||||
$stream = $this->getStream($fileName, 'r+', 6);
|
||||
$this->assertEquals(3, fwrite($stream, 'bar'));
|
||||
fclose($stream);
|
||||
|
@ -176,6 +167,8 @@ class Encryption extends \Test\TestCase {
|
|||
$stream = $this->getStream($fileName, 'r', 6);
|
||||
$this->assertEquals('barbar', fread($stream, 100));
|
||||
fclose($stream);
|
||||
|
||||
unlink($fileName);
|
||||
}
|
||||
|
||||
public function testRewind() {
|
||||
|
@ -191,7 +184,9 @@ class Encryption extends \Test\TestCase {
|
|||
$stream = $this->getStream($fileName, 'r', 6);
|
||||
$this->assertEquals('barbar', fread($stream, 100));
|
||||
fclose($stream);
|
||||
}
|
||||
|
||||
unlink($fileName);
|
||||
}
|
||||
|
||||
public function testSeek() {
|
||||
$fileName = tempnam("/tmp", "FOO");
|
||||
|
@ -203,6 +198,12 @@ class Encryption extends \Test\TestCase {
|
|||
|
||||
$stream = $this->getStream($fileName, 'r', 9);
|
||||
$this->assertEquals('foofoobar', fread($stream, 100));
|
||||
$this->assertEquals(-1, fseek($stream, 10));
|
||||
$this->assertEquals(0, fseek($stream, 9));
|
||||
$this->assertEquals(-1, fseek($stream, -10, SEEK_CUR));
|
||||
$this->assertEquals(0, fseek($stream, -9, SEEK_CUR));
|
||||
$this->assertEquals(-1, fseek($stream, -10, SEEK_END));
|
||||
$this->assertEquals(0, fseek($stream, -9, SEEK_END));
|
||||
fclose($stream);
|
||||
|
||||
unlink($fileName);
|
||||
|
|
Loading…
Reference in a new issue