gianksp/cakephp-amazon-s3

Amazon S3 Plugin for CakePHP

Installs: 78 553

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 14

Open Issues: 0

Type:cakephp-plugin

dev-master 2017-06-05 16:55 UTC

This package is not auto-updated.

Last update: 2024-04-28 02:11:05 UTC


README

A CakePHP Plugin to interact with Amazon Web Services S3 objects. This plugin provides a simple and robust methods that can be added to any CakePHP project to complete the following:

  • Retrieve a remote file from an S3 bucket and save locally
  • Save a local file in an S3 bucket
  • Delete a file in an S3 bucket

Requirements

Installation

composer require gianksp/cakephp-amazon-s3:dev-master

Usuage examples

Remember to add CakePlugin::load('AmazonS3'); to your app's bootstrap file.

Then, simply initialise the plugin with your AWS Access key, secret key and the bucket name you wish to work with.

App::uses('AmazonS3', 'AmazonS3.Lib');
$AmazonS3 = new AmazonS3(array('{access key}', '{secret key}', '{bucket name}'));

GET

The get method retrieves a remote file and saves it locally. So let's say there is the file foo.jpg on S3 and you want to save it locally in /home/me/stuff/photos you'd use the following.

$AmazonS3->get('foo.jpg' , '/home/me/stuff/photos');

PUT

The put method does the reverse of get, and saves a local file to S3.

$AmazonS3->put('/home/me/stuff/photos/foo.jpg');

You can optionally specifiy a remote directory within the bucket to save the file in. Be sure not to include a starting / in the remote directory string.

$AmazonS3->put('/home/me/stuff/photos/foo.jpg' , 'some/folder');

To add any additional AWS headers to a put, example to set the file as "public", they can be passed as an array to the amazonHeaders property.

$AmazonS3->amazonHeaders = array(
	'x-amz-acl' => 'public-read',
	'X-Amz-Meta-ReviewedBy' => 'john.doe@yahoo.biz'
);
$AmazonS3->put('/home/me/stuff/photos/foo.jpg' , 'some/folder');

DELETE

Deletes a file from S3.

$AmazonS3->delete('foo.jpg');

Or delete from within a directory in the bucket. Be sure not to include a starting / in the string or you will receive a SignatureDoesNotMatch error:

$AmazonS3->delete('some/folder/foo.jpg');