aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorblizzz <blizzz@arthur-schiwon.de>2021-09-23 09:49:45 +0200
committerGitHub <noreply@github.com>2021-09-23 09:49:45 +0200
commit815ec82cd072264052499bae572d33b976d4259b (patch)
treedffc0d1d7bc730fe80569912ed7d64073f2414e4 /lib
parent3985791360421dc81fbb320219c9c145fa8d8358 (diff)
parent11695164c63b921e8c90ab82c340cda4cf530d83 (diff)
downloadnextcloud-server-815ec82cd072264052499bae572d33b976d4259b.tar.gz
nextcloud-server-815ec82cd072264052499bae572d33b976d4259b.zip
Merge pull request #28910 from nextcloud/backport/28802/stable22
[stable22] Support seeking also from the end of file on S3 storage
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Files/Stream/SeekableHttpStream.php11
1 files changed, 10 insertions, 1 deletions
diff --git a/lib/private/Files/Stream/SeekableHttpStream.php b/lib/private/Files/Stream/SeekableHttpStream.php
index c6d34e67cc9..af797c7720d 100644
--- a/lib/private/Files/Stream/SeekableHttpStream.php
+++ b/lib/private/Files/Stream/SeekableHttpStream.php
@@ -76,6 +76,8 @@ class SeekableHttpStream implements File {
private $current;
/** @var int */
private $offset = 0;
+ /** @var int */
+ private $length = 0;
private function reconnect(int $start) {
$range = $start . '-';
@@ -101,12 +103,14 @@ class SeekableHttpStream implements File {
$content = trim(explode(':', $contentRange)[1]);
$range = trim(explode(' ', $content)[1]);
$begin = intval(explode('-', $range)[0]);
+ $length = intval(explode('/', $range)[1]);
if ($begin !== $start) {
return false;
}
$this->offset = $begin;
+ $this->length = $length;
return true;
}
@@ -140,7 +144,12 @@ class SeekableHttpStream implements File {
}
return $this->reconnect($this->offset + $offset);
case SEEK_END:
- return false;
+ if ($this->length === 0) {
+ return false;
+ } elseif ($this->length + $offset === $this->offset) {
+ return true;
+ }
+ return $this->reconnect($this->length + $offset);
}
return false;
}