anton-am / do-spaces-api
An API wrapper for DigitalOcean's Spaces object storage designed for easy use.
1.0.5
2021-05-21 08:54 UTC
Requires
- php: >=7.2.0
- ext-json: *
- ext-simplexml: *
- aws/aws-sdk-php: ^3.108
- guzzlehttp/guzzle: ^6.3
- mtdowling/jmespath.php: ^2.4
- psr/http-message: ^1.0
Requires (Dev)
- codeception/codeception: ~2.5
- codeclimate/php-test-reporter: 0.4.4
- phpunit/php-code-coverage: ~6.0
- squizlabs/php_codesniffer: ~3.4
- vlucas/phpdotenv: 3.4.0
README
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 ) */ }