aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorJulius Härtl <jus@bitgrid.net>2023-12-28 15:31:08 +0100
committerJulius Härtl <jus@bitgrid.net>2023-12-28 15:31:38 +0100
commite4054370b1e3fff36f532f5543d89d31faec1380 (patch)
treea9f64624b6619faffdd32bbfa20011ca8d0fc9e6 /lib
parent1043c21b35f256619e4970a6fd0746b0dc2c9d3f (diff)
downloadnextcloud-server-e4054370b1e3fff36f532f5543d89d31faec1380.tar.gz
nextcloud-server-e4054370b1e3fff36f532f5543d89d31faec1380.zip
fix(s3): Add config option to disable multipart copy for certain s3 providers
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Files/ObjectStore/S3ConnectionTrait.php3
-rw-r--r--lib/private/Files/ObjectStore/S3ObjectTrait.php2
2 files changed, 4 insertions, 1 deletions
diff --git a/lib/private/Files/ObjectStore/S3ConnectionTrait.php b/lib/private/Files/ObjectStore/S3ConnectionTrait.php
index 1a682567e0c..a1edfa1eb99 100644
--- a/lib/private/Files/ObjectStore/S3ConnectionTrait.php
+++ b/lib/private/Files/ObjectStore/S3ConnectionTrait.php
@@ -74,6 +74,8 @@ trait S3ConnectionTrait {
/** @var int */
private $copySizeLimit;
+ private bool $useMultipartCopy = true;
+
protected $test;
protected function parseParams($params) {
@@ -91,6 +93,7 @@ trait S3ConnectionTrait {
$this->uploadPartSize = $params['uploadPartSize'] ?? 524288000;
$this->putSizeLimit = $params['putSizeLimit'] ?? 104857600;
$this->copySizeLimit = $params['copySizeLimit'] ?? 5242880000;
+ $this->useMultipartCopy = (bool)($params['useMultipartCopy'] ?? true);
$params['region'] = empty($params['region']) ? 'eu-west-1' : $params['region'];
$params['hostname'] = empty($params['hostname']) ? 's3.' . $params['region'] . '.amazonaws.com' : $params['hostname'];
if (!isset($params['port']) || $params['port'] === '') {
diff --git a/lib/private/Files/ObjectStore/S3ObjectTrait.php b/lib/private/Files/ObjectStore/S3ObjectTrait.php
index 65952a76a61..2ef9614ac85 100644
--- a/lib/private/Files/ObjectStore/S3ObjectTrait.php
+++ b/lib/private/Files/ObjectStore/S3ObjectTrait.php
@@ -198,7 +198,7 @@ trait S3ObjectTrait {
$size = (int)($sourceMetadata->get('Size') ?? $sourceMetadata->get('ContentLength'));
- if ($size > $this->copySizeLimit) {
+ if ($this->useMultipartCopy && $size > $this->copySizeLimit) {
$copy = new MultipartCopy($this->getConnection(), [
"source_bucket" => $this->getBucket(),
"source_key" => $from