summaryrefslogtreecommitdiffstats
path: root/lib/private/Files
diff options
context:
space:
mode:
authorRoeland Jago Douma <roeland@famdouma.nl>2019-02-14 15:51:40 +0100
committerRoeland Jago Douma <roeland@famdouma.nl>2019-02-15 08:41:39 +0100
commit61d66d79544e3bd17a4f96a569fc24596ec414db (patch)
tree781f5842dfe4066768267b645b04b83c01f2f387 /lib/private/Files
parent49a0ea01e53be89c4a8bccf26e2327f6f5c41fc5 (diff)
downloadnextcloud-server-61d66d79544e3bd17a4f96a569fc24596ec414db.tar.gz
nextcloud-server-61d66d79544e3bd17a4f96a569fc24596ec414db.zip
Fix empty file uploads to S3
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
Diffstat (limited to 'lib/private/Files')
-rw-r--r--lib/private/Files/ObjectStore/S3ObjectTrait.php25
1 files changed, 23 insertions, 2 deletions
diff --git a/lib/private/Files/ObjectStore/S3ObjectTrait.php b/lib/private/Files/ObjectStore/S3ObjectTrait.php
index 0b55c319ea8..7c46ba25c11 100644
--- a/lib/private/Files/ObjectStore/S3ObjectTrait.php
+++ b/lib/private/Files/ObjectStore/S3ObjectTrait.php
@@ -23,8 +23,11 @@
namespace OC\Files\ObjectStore;
+use Aws\S3\Exception\S3MultipartUploadException;
use Aws\S3\MultipartUploader;
+use Aws\S3\ObjectUploader;
use Aws\S3\S3Client;
+use Icewind\Streams\CallbackWrapper;
const S3_UPLOAD_PART_SIZE = 524288000; // 500MB
@@ -73,12 +76,30 @@ trait S3ObjectTrait {
* @since 7.0.0
*/
function writeObject($urn, $stream) {
- $uploader = new MultipartUploader($this->getConnection(), $stream, [
+ $count = 0;
+ $countStream = CallbackWrapper::wrap($stream, function ($read) use (&$count) {
+ $count += $read;
+ });
+
+ $uploader = new MultipartUploader($this->getConnection(), $countStream, [
'bucket' => $this->bucket,
'key' => $urn,
'part_size' => S3_UPLOAD_PART_SIZE
]);
- $uploader->upload();
+
+ try {
+ $uploader->upload();
+ } catch (S3MultipartUploadException $e) {
+ // This is an emty file so just touch it then
+ if ($count === 0 && feof($countStream)) {
+ $uploader = new ObjectUploader($this->getConnection(), $this->bucket, $urn, '');
+ $uploader->upload();
+ } else {
+ throw $e;
+ }
+ }
+
+ fclose($countStream);
}
/**