An API wrapper for DigitalOcean's Spaces object storage designed for easy use.
Find a file
Florian DE LA COMBLE 08c95b254a
fclose($file) exception.
It happens that fclose trigger an Exception because the resource is already closed.
After investigation, it seems that the $file get closed in the putObject function (l. 274) when the garbage collector clean the memory.
The change fix this issue.

Here is the related issue on the aws sdk repo: 
https://github.com/aws/aws-sdk-php/issues/929
2019-07-27 16:42:35 +02:00
aws Delete .DS_Store 2017-12-07 21:24:35 +05:30
composer.json Update composer.json 2018-02-07 21:01:20 +05:30
LICENSE Initial commit 2017-12-07 20:59:09 +05:30
README.md Merge pull request #27 from Abdelhady/patch-2 2019-06-05 02:07:39 +05:30
spaces.php fclose($file) exception. 2019-07-27 16:42:35 +02:00

Spaces-API

FOSSA Status

An API wrapper for DigitalOcean's Spaces object storage designed for easy use.

Installation

  • Using Composer:
composer require sociallydev/spaces-api:dev-master

Connecting

//Either:
require_once("spaces.php");
//OR COMPOSER:
require_once("vendor/autoload.php"); //Install first by executing: composer require SociallyDev/Spaces-API in your project's directory.

$key = "EXAMPLE_KEY";
$secret = "EXAMPLE_SECRET";

$space_name = "my-space";
$region = "nyc3";

$space = new SpacesConnect($key, $secret, $space_name, $region);

All available options:

SpacesConnect(REQUIRED KEY, REQUIRED SECRET, OPTIONAL SPACE's NAME, OPTIONAL REGION, OPTIONAL HOST);

 

Uploading/Downloading Files

// Don't start any path with a forward slash, or it will give "SignatureDoesNotMatch" exception
$path_to_file = "image.png";

$space->UploadFile($path_to_file, "public");



$download_file = "image.png";
$save_as = "folder/downloaded-image.png";

$space->DownloadFile($download_file, $save_as);

All available options:

UploadFile(REQUIRED PATH TO FILE, OPTIONAL PRIVACY (public|private) OPTIONAL NAME TO SAVE FILE AS);
DownloadFile(REQUIRED FILE TO DOWNLOAD, REQUIRED LOCATION TO SAVE IN);

 

Deleting Files/Folders


$file_name = "image.png";

$space->DeleteObject($file_name);

All available options:

DeleteObject(REQUIRED FILE OR FOLDER TO DELETE, OPTIONAL RECURSIVE (false|true));

 

Changing Privacy Settings

$file = "image.png";

$space->MakePublic($file);
$space->MakePrivate($file);

All available options:

MakePublic(REQUIRED PATH TO FILE);
MakePrivate(REQUIRED PATH TO FILE);

 

$file = "image.png";
$valid_for = "1 day";

$link = $space->CreateTemporaryURL($file, $valid_for);

All available options:

   

Other File APIs

//List all files and folders
$files = $space->ListObjects();


//Check if a file/folder by that name already exists. True/False.
$space->DoesObjectExist($file_name);


//Pull information about a single object.
$file_info = $space->GetObject($file_name);


//Upload a complete directory instead of a single file.
$space->UploadDirectory($path_to_directory, $key_prefix);


//Pull Access Control List information.
$acl = $space-ListObjectACL($file_name);


//Update Access Control List information.
$space->PutObjectACL($file_name, $acl_info_array);

         

Creating Spaces

$new_space = "my-new-space";

$space->CreateSpace($new_space);

All available options:

CreateSpace(REQUIRED SPACE NAME, OPTIONAL REGION FOR SPACE);

 

Switching Spaces

$new_space = "my-new-space";

$space->SetSpace($new_space);

All available options:

SetSpace(REQUIRED SPACE NAME, OPTIONAL REGION FOR SPACE, OPTIONAL HOST);

   

Other Spaces APIs

//List all Spaces available in account.
$spaces = $space->ListSpaces();


//Delete a Space.
$space->DestroyThisSpace();


//Download whole Space to a folder.
$space->DownloadSpaceToDirectory($directory_to_download_to);


//Get the name of the current Space.
$space_name = $space->GetSpaceName();


//Pull the CORS policy of the Space.
$cors = $space->ListCORS();


//Update the CORS policy of the Space.
$space->PutCORS($new_policy);


//Pull the Access Control List information of the Space.
$acl = $space->ListSpaceACL();


//Update the Access Control List information of the Space.
$space->PutSpaceACL($new_acl);

Handling Errors

try {
   $space->CreateSpace("dev");
} catch (\SpacesAPIException $e) {
  $error = $e->GetError();

   //Error management code.
   echo "<pre>";
   print_r($error);
   /*
   EG:
   Array (
    [message] => Bucket already exists
    [code] => BucketAlreadyExists
    [type] => client
    [http_code] => 409
   )
   */
}

License

FOSSA Status