diff options
author | Robin Appelman <robin@icewind.nl> | 2022-03-15 15:50:08 +0100 |
---|---|---|
committer | Robin Appelman <robin@icewind.nl> | 2022-03-15 15:50:08 +0100 |
commit | 1156214a269572b4460d8aa8a599076520f26b58 (patch) | |
tree | 6187ce63b005251c6958c411f6685f3b53782bae /lib/private | |
parent | a887553ddb44e6db71b6605ddcf678c38b2442a1 (diff) | |
download | nextcloud-server-1156214a269572b4460d8aa8a599076520f26b58.tar.gz nextcloud-server-1156214a269572b4460d8aa8a599076520f26b58.zip |
don't try to get custom certs for s3 primary storage
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/Files/ObjectStore/S3.php | 1 | ||||
-rw-r--r-- | lib/private/Files/ObjectStore/S3ConnectionTrait.php | 12 |
2 files changed, 10 insertions, 3 deletions
diff --git a/lib/private/Files/ObjectStore/S3.php b/lib/private/Files/ObjectStore/S3.php index 074f3a1df91..6492145fb63 100644 --- a/lib/private/Files/ObjectStore/S3.php +++ b/lib/private/Files/ObjectStore/S3.php @@ -30,6 +30,7 @@ class S3 implements IObjectStore { use S3ObjectTrait; public function __construct($parameters) { + $parameters['primary_storage'] = true; $this->parseParams($parameters); } diff --git a/lib/private/Files/ObjectStore/S3ConnectionTrait.php b/lib/private/Files/ObjectStore/S3ConnectionTrait.php index e4085676c18..d6f42c455b4 100644 --- a/lib/private/Files/ObjectStore/S3ConnectionTrait.php +++ b/lib/private/Files/ObjectStore/S3ConnectionTrait.php @@ -121,8 +121,14 @@ trait S3ConnectionTrait { ) ); - /** @var ICertificateManager $certManager */ - $certManager = \OC::$server->get(ICertificateManager::class); + // since we store the certificate bundles on the primary storage, we can't get the bundle while setting up the primary storage + if (!isset($this->params['primary_storage'])) { + /** @var ICertificateManager $certManager */ + $certManager = \OC::$server->get(ICertificateManager::class); + $certPath = $certManager->getAbsoluteBundlePath(); + } else { + $certPath = \OC::$SERVERROOT . '/resources/config/ca-bundle.crt'; + } $options = [ 'version' => isset($this->params['version']) ? $this->params['version'] : 'latest', @@ -133,7 +139,7 @@ trait S3ConnectionTrait { 'signature_provider' => \Aws\or_chain([self::class, 'legacySignatureProvider'], ClientResolver::_default_signature_provider()), 'csm' => false, 'use_arn_region' => false, - 'http' => ['verify' => $certManager->getAbsoluteBundlePath()], + 'http' => ['verify' => $certPath], ]; if ($this->getProxy()) { $options['http']['proxy'] = $this->getProxy(); |