backblaze-b2
is the SDK for working with Backblaze's B2 storage service.
Via Composer
$ composer require gliterd/backblaze-b2
use BackblazeB2\Client;
use BackblazeB2\Bucket;
$options = ['auth_timeout_seconds' => seconds];
$client = new Client('accountId', 'applicationKey', $options);
$options is optional. If omitted, the default timeout is 12 hours. The timeout allows for a long lived Client object so that the authorization token does not expire.
$bucket = $client->createBucket([
'BucketName' => 'my-special-bucket',
'BucketType' => Bucket::TYPE_PRIVATE // or TYPE_PUBLIC
]);
$updatedBucket = $client->updateBucket([
'BucketId' => $bucket->getId(),
'BucketType' => Bucket::TYPE_PUBLIC
]);
$buckets = $client->listBuckets();
$client->deleteBucket([
'BucketId' => 'YOUR_BUCKET_ID'
]);
$file = $client->upload([
'BucketName' => 'my-special-bucket',
'FileName' => 'path/to/upload/to',
'Body' => 'I am the file content'
// The file content can also be provided via a resource.
// 'Body' => fopen('/path/to/input', 'r')
]);
$fileContent = $client->download([
'FileId' => $file->getId()
// Can also identify the file via bucket and path:
// 'BucketName' => 'my-special-bucket',
// 'FileName' => 'path/to/file'
// Can also save directly to a location on disk. This will cause download() to not return file content.
// 'SaveAs' => '/path/to/save/location'
]);
$copyOfFile = $client->copy([
'BucketName' => $bucketName,
'FileName' => $path,
'SaveAs' => $newPath,
// Can also supply BucketId instead of BucketName
// Optional are DestinationBucketName or DestinationBucketId
]);
$fileDelete = $client->deleteFile([
'FileId' => $file->getId()
// Can also identify the file via bucket and path:
// 'BucketName' => 'my-special-bucket',
// 'FileName' => 'path/to/file'
]);
$fileList = $client->listFiles([
'BucketId' => 'YOUR_BUCKET_ID'
]);
Please see CHANGELOG for more information what has changed recently.
$ vendor/bin/phpunit
Please see CONTRIBUTING and CONDUCT for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.