mirror of
https://github.com/SociallyDev/Spaces-API.git
synced 2025-07-16 10:03:01 -07:00
An API wrapper for DigitalOcean's Spaces object storage designed for easy use.
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 |
||
---|---|---|
aws | ||
composer.json | ||
LICENSE | ||
README.md | ||
spaces.php |
Spaces-API
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);
Creating Temporary Links
$file = "image.png";
$valid_for = "1 day";
$link = $space->CreateTemporaryURL($file, $valid_for);
All available options:
CreateTemporaryURL(REQUIRED FILE NAME, OPTIONAL TIME LINK IS VALID FOR);
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
)
*/
}