diff options
author | Robin Appelman <robin@icewind.nl> | 2017-04-20 17:08:22 +0200 |
---|---|---|
committer | Robin Appelman <robin@icewind.nl> | 2017-10-03 14:09:59 +0200 |
commit | f62e0a33f328f68430bd984059c6223512ec7168 (patch) | |
tree | 3dc07122f4adab8afa4ed4a88c80c8edce00ae11 /apps/files_external/lib | |
parent | 14d94abf06c0e33638528cd94ae4b0e5f7e87df4 (diff) | |
download | nextcloud-server-f62e0a33f328f68430bd984059c6223512ec7168.tar.gz nextcloud-server-f62e0a33f328f68430bd984059c6223512ec7168.zip |
update aws sdk and move it to 3rdparty
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'apps/files_external/lib')
-rw-r--r-- | apps/files_external/lib/Lib/Storage/AmazonS3.php | 38 |
1 files changed, 21 insertions, 17 deletions
diff --git a/apps/files_external/lib/Lib/Storage/AmazonS3.php b/apps/files_external/lib/Lib/Storage/AmazonS3.php index 9dab25f7197..edcc084ae44 100644 --- a/apps/files_external/lib/Lib/Storage/AmazonS3.php +++ b/apps/files_external/lib/Lib/Storage/AmazonS3.php @@ -36,10 +36,6 @@ namespace OCA\Files_External\Lib\Storage; -set_include_path(get_include_path() . PATH_SEPARATOR . - \OC_App::getAppPath('files_external') . '/3rdparty/aws-sdk-php'); -require_once 'aws-autoloader.php'; - use Aws\S3\S3Client; use Aws\S3\Exception\S3Exception; use Icewind\Streams\CallbackWrapper; @@ -230,21 +226,29 @@ class AmazonS3 extends \OC\Files\Storage\Common { try { $files = array(); - $result = $this->getConnection()->getIterator('ListObjects', array( + $results = $this->getConnection()->getPaginator('ListObjects', [ 'Bucket' => $this->bucket, 'Delimiter' => '/', - 'Prefix' => $path - ), array('return_prefixes' => true)); - - foreach ($result as $object) { - if (isset($object['Key']) && $object['Key'] === $path) { - // it's the directory itself, skip - continue; + 'Prefix' => $path, + ]); + + foreach ($results as $result) { + // sub folders + if (is_array($result['CommonPrefixes'])) { + foreach ($result['CommonPrefixes'] as $prefix) { + $files[] = substr(trim($prefix['Prefix'], '/'), strlen($path)); + } + } + foreach ($result['Contents'] as $object) { + if (isset($object['Key']) && $object['Key'] === $path) { + // it's the directory itself, skip + continue; + } + $file = basename( + isset($object['Key']) ? $object['Key'] : $object['Prefix'] + ); + $files[] = $file; } - $file = basename( - isset($object['Key']) ? $object['Key'] : $object['Prefix'] - ); - $files[] = $file; } return IteratorDirectory::wrap($files); @@ -270,7 +274,7 @@ class AmazonS3 extends \OC\Files\Storage\Common { )); $stat['size'] = $result['ContentLength'] ? $result['ContentLength'] : 0; - if ($result['Metadata']['lastmodified']) { + if (isset($result['Metadata']['lastmodified'])) { $stat['mtime'] = strtotime($result['Metadata']['lastmodified']); } else { $stat['mtime'] = strtotime($result['LastModified']); |