diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2017-12-08 09:26:41 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-12-08 09:26:41 +0100 |
commit | ac29608db6816312b7d558fc3ac8b86ad34ad282 (patch) | |
tree | 26fe35b2cb5f436ca94f211707cf04c679acc3e1 | |
parent | c9318ddd1b32afaff4f339bc656938444a891009 (diff) | |
parent | 0519ca589381b2473fa23a135efb185f29c71649 (diff) | |
download | nextcloud-server-ac29608db6816312b7d558fc3ac8b86ad34ad282.tar.gz nextcloud-server-ac29608db6816312b7d558fc3ac8b86ad34ad282.zip |
Merge pull request #7409 from nextcloud/swift-retry-12
[12]add retry wrapper when reading files from swift
-rw-r--r-- | apps/files_external/lib/Lib/Storage/Swift.php | 3 | ||||
-rw-r--r-- | lib/private/Files/ObjectStore/Swift.php | 3 |
2 files changed, 4 insertions, 2 deletions
diff --git a/apps/files_external/lib/Lib/Storage/Swift.php b/apps/files_external/lib/Lib/Storage/Swift.php index d32d6b3a19c..ff6b1e6271b 100644 --- a/apps/files_external/lib/Lib/Storage/Swift.php +++ b/apps/files_external/lib/Lib/Storage/Swift.php @@ -39,6 +39,7 @@ use Guzzle\Http\Url; use Guzzle\Http\Exception\ClientErrorResponseException; use Icewind\Streams\CallbackWrapper; use Icewind\Streams\IteratorDirectory; +use Icewind\Streams\RetryWrapper; use OpenCloud; use OpenCloud\Common\Exceptions; use OpenCloud\OpenStack; @@ -385,7 +386,7 @@ class Swift extends \OC\Files\Storage\Common { stream_context_set_option($stream, 'swift','content', $streamInterface); if(!strrpos($streamInterface ->getMetaData('wrapper_data')[0], '404 Not Found')) { - return $stream; + return RetryWrapper::wrap($stream); } return false; } catch (\Guzzle\Http\Exception\BadResponseException $e) { diff --git a/lib/private/Files/ObjectStore/Swift.php b/lib/private/Files/ObjectStore/Swift.php index 36a1a4a873f..725ed7fcaf3 100644 --- a/lib/private/Files/ObjectStore/Swift.php +++ b/lib/private/Files/ObjectStore/Swift.php @@ -25,6 +25,7 @@ namespace OC\Files\ObjectStore; use Guzzle\Http\Exception\ClientErrorResponseException; +use Icewind\Streams\RetryWrapper; use OCP\Files\ObjectStore\IObjectStore; use OCP\Files\StorageAuthException; use OCP\Files\StorageNotAvailableException; @@ -263,7 +264,7 @@ class Swift implements IObjectStore { // save the object content in the context of the stream to prevent it being gc'd until the stream is closed stream_context_set_option($stream, 'swift', 'content', $objectContent); - return $stream; + RetryWrapper::wrap($stream); } /** |