From 7d915e128ce9822bcd1523e27d59246f86f4562f Mon Sep 17 00:00:00 2001 From: Ahmad Fikrizaman Date: Thu, 24 Aug 2017 14:28:17 +0800 Subject: [PATCH] enable read stream --- composer.json | 2 +- src/BackblazeAdapter.php | 54 +++++++++++++++++++++++++--------------- 2 files changed, 35 insertions(+), 21 deletions(-) diff --git a/composer.json b/composer.json index a5904ca..a58e49a 100755 --- a/composer.json +++ b/composer.json @@ -16,7 +16,7 @@ "require": { "php": ">=5.5.0", "league/flysystem": "~1.0", - "cwhite92/b2-sdk-php" : "^1.2", + "runcloudio/b2-sdk-php" : "^1.2", "mikey179/vfsStream" : "*" }, "require-dev": { diff --git a/src/BackblazeAdapter.php b/src/BackblazeAdapter.php index a7a574d..cfaffa6 100755 --- a/src/BackblazeAdapter.php +++ b/src/BackblazeAdapter.php @@ -3,11 +3,13 @@ namespace Mhetreramesh\Flysystem; use ChrisWhite\B2\Client; +use GuzzleHttp\Psr7\StreamWrapper; use League\Flysystem\Adapter\AbstractAdapter; use League\Flysystem\Adapter\Polyfill\NotSupportingVisibilityTrait; use League\Flysystem\Config; -class BackblazeAdapter extends AbstractAdapter { +class BackblazeAdapter extends AbstractAdapter +{ use NotSupportingVisibilityTrait; @@ -17,7 +19,7 @@ class BackblazeAdapter extends AbstractAdapter { public function __construct(Client $client, $bucketName) { - $this->client = $client; + $this->client = $client; $this->bucketName = $bucketName; } @@ -36,8 +38,8 @@ public function write($path, $contents, Config $config) { $file = $this->getClient()->upload([ 'BucketName' => $this->bucketName, - 'FileName' => $path, - 'Body' => $contents + 'FileName' => $path, + 'Body' => $contents, ]); return $this->getFileInfo($file); } @@ -49,8 +51,8 @@ public function writeStream($path, $resource, Config $config) { $file = $this->getClient()->upload([ 'BucketName' => $this->bucketName, - 'FileName' => $path, - 'Body' => $resource + 'FileName' => $path, + 'Body' => $resource, ]); return $this->getFileInfo($file); } @@ -62,8 +64,8 @@ public function update($path, $contents, Config $config) { $file = $this->getClient()->upload([ 'BucketName' => $this->bucketName, - 'FileName' => $path, - 'Body' => $contents + 'FileName' => $path, + 'Body' => $contents, ]); return $this->getFileInfo($file); } @@ -75,8 +77,8 @@ public function updateStream($path, $resource, Config $config) { $file = $this->getClient()->upload([ 'BucketName' => $this->bucketName, - 'FileName' => $path, - 'Body' => $resource + 'FileName' => $path, + 'Body' => $resource, ]); return $this->getFileInfo($file); } @@ -88,10 +90,10 @@ public function read($path) { $file = $this->getClient()->getFile([ 'BucketName' => $this->bucketName, - 'FileName' => $path + 'FileName' => $path, ]); $fileContent = $this->getClient()->download([ - 'FileId' => $file->getId() + 'FileId' => $file->getId(), ]); return ['contents' => $fileContent]; } @@ -101,7 +103,19 @@ public function read($path) */ public function readStream($path) { - return false; + $file = $this->getClient()->getFile([ + 'BucketName' => $this->bucketName, + 'FileName' => $path, + ]); + + $fileContent = $this->getClient()->download([ + 'FileId' => $file->getId(), + 'stream' => true, + ]); + + $resource = StreamWrapper::getResource($fileContent); + + return ['type' => 'file', 'path' => $path, 'stream' => $resource]; } /** @@ -119,8 +133,8 @@ public function copy($path, $newPath) { return $this->getClient()->upload([ 'BucketName' => $this->bucketName, - 'FileName' => $newPath, - 'Body' => @file_get_contents($path) + 'FileName' => $newPath, + 'Body' => @file_get_contents($path), ]); } @@ -147,8 +161,8 @@ public function createDir($path, Config $config) { return $this->getClient()->upload([ 'BucketName' => $this->bucketName, - 'FileName' => $path, - 'Body' => '' + 'FileName' => $path, + 'Body' => '', ]); } @@ -222,10 +236,10 @@ public function listContents($directory = '', $recursive = false) protected function getFileInfo($file) { $normalized = [ - 'type' => 'file', - 'path' => $file->getName(), + 'type' => 'file', + 'path' => $file->getName(), 'timestamp' => substr($file->getUploadTimestamp(), 0, -3), - 'size' => $file->getSize() + 'size' => $file->getSize(), ]; return $normalized;