summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoeland Jago Douma <rullzer@users.noreply.github.com>2020-08-20 20:28:05 +0200
committerGitHub <noreply@github.com>2020-08-20 20:28:05 +0200
commit6e4b0892650c4c90a4a0fb35baacab6c0d4913bf (patch)
tree300b29e780c39144a898569a87c518a1690e2fd7
parent987f62117351a658dc8c0916e38cfb0b7ca60982 (diff)
parent5ef0f86ce7c7b7b618530c713b8e256b5ccf43cc (diff)
downloadnextcloud-server-6e4b0892650c4c90a4a0fb35baacab6c0d4913bf.tar.gz
nextcloud-server-6e4b0892650c4c90a4a0fb35baacab6c0d4913bf.zip
Merge pull request #20891 from cuppett/cuppett/issue#19790
Resolves #19790, Provides Support for IAM Credentials
-rw-r--r--lib/private/Files/ObjectStore/S3ConnectionTrait.php44
1 files changed, 38 insertions, 6 deletions
diff --git a/lib/private/Files/ObjectStore/S3ConnectionTrait.php b/lib/private/Files/ObjectStore/S3ConnectionTrait.php
index b96a11833cd..d4954c99572 100644
--- a/lib/private/Files/ObjectStore/S3ConnectionTrait.php
+++ b/lib/private/Files/ObjectStore/S3ConnectionTrait.php
@@ -7,6 +7,7 @@
* @author Morris Jobke <hey@morrisjobke.de>
* @author Robin Appelman <robin@icewind.nl>
* @author S. Cat <33800996+sparrowjack63@users.noreply.github.com>
+ * @author Stephen Cuppett <steve@cuppett.com>
*
* @license GNU AGPL version 3 or any later version
*
@@ -28,8 +29,13 @@
namespace OC\Files\ObjectStore;
use Aws\ClientResolver;
+use Aws\Credentials\CredentialProvider;
+use Aws\Credentials\Credentials;
+use Aws\Exception\CredentialsException;
use Aws\S3\Exception\S3Exception;
use Aws\S3\S3Client;
+use GuzzleHttp\Promise;
+use GuzzleHttp\Promise\RejectedPromise;
use OCP\ILogger;
trait S3ConnectionTrait {
@@ -54,8 +60,8 @@ trait S3ConnectionTrait {
protected $test;
protected function parseParams($params) {
- if (empty($params['key']) || empty($params['secret']) || empty($params['bucket'])) {
- throw new \Exception("Access Key, Secret and Bucket have to be configured.");
+ if (empty($params['bucket'])) {
+ throw new \Exception("Bucket has to be configured.");
}
$this->id = 'amazon::' . $params['bucket'];
@@ -90,12 +96,19 @@ trait S3ConnectionTrait {
$scheme = (isset($this->params['use_ssl']) && $this->params['use_ssl'] === false) ? 'http' : 'https';
$base_url = $scheme . '://' . $this->params['hostname'] . ':' . $this->params['port'] . '/';
+ // Adding explicit credential provider to the beginning chain.
+ // Including environment variables and IAM instance profiles.
+ $provider = CredentialProvider::memoize(
+ CredentialProvider::chain(
+ $this->paramCredentialProvider(),
+ CredentialProvider::env(),
+ CredentialProvider::instanceProfile()
+ )
+ );
+
$options = [
'version' => isset($this->params['version']) ? $this->params['version'] : 'latest',
- 'credentials' => [
- 'key' => $this->params['key'],
- 'secret' => $this->params['secret'],
- ],
+ 'credentials' => $provider,
'endpoint' => $base_url,
'region' => $this->params['region'],
'use_path_style_endpoint' => isset($this->params['use_path_style']) ? $this->params['use_path_style'] : false,
@@ -161,4 +174,23 @@ trait S3ConnectionTrait {
return null;
}
}
+
+ /**
+ * This function creates a credential provider based on user parameter file
+ */
+ protected function paramCredentialProvider() : callable {
+ return function () {
+ $key = empty($this->params['key']) ? null : $this->params['key'];
+ $secret = empty($this->params['secret']) ? null : $this->params['secret'];
+
+ if ($key && $secret) {
+ return Promise\promise_for(
+ new Credentials($key, $secret)
+ );
+ }
+
+ $msg = 'Could not find parameters set for credentials in config file.';
+ return new RejectedPromise(new CredentialsException($msg));
+ };
+ }
}