thomaswelton / laravel-rackspace-opencloud
Installs: 15 141
Dependents: 1
Suggesters: 0
Security: 0
Stars: 29
Watchers: 2
Forks: 14
Open Issues: 12
Requires
- php: >=5.3.0
- alchemy/zippy: 0.1.0
- illuminate/support: 4.x
- rackspace/php-opencloud: 1.5.*
README
Installation
Update your composer.json
file to include this package as a dependency
"thomaswelton/laravel-rackspace-opencloud": "dev-master"
Register the OpenCloud service provider by adding it to the providers array in your app/config/app.php
file.
'providers' => array( Thomaswelton\LaravelRackspaceOpencloud\LaravelRackspaceOpencloudServiceProvider )
Alias the OpenCloud facade by adding it to the aliases array in the app/config/app.php
file.
'aliases' => array( 'OpenCloud' => 'Thomaswelton\LaravelRackspaceOpencloud\Facades\OpenCloud' )
Configuration
Copy the config file into your project by running
php artisan config:publish thomaswelton/laravel-rackspace-opencloud
Edit the config file to include your username, api key and region.
Usage
Artisan Commands
Upload files via the command line.
Synchronize a whole directory. Copies all files to /public/assets
php artisan cdn:sync public/assets
Copies all files to /assets trimming 'public' from the path
php artisan cdn:sync public/assets --trim=public
The sync command will save a file adjacent to the synchronized directory. It contains the http and https urls for your container. Along with a md5 hash of the directory. In this way when a file changes inside a directory and is reuploaded you get a new cache busted URL.
If you are using the URL helper then it will return a CDN url for a file, if it finds a *.cdn.json file adjacent to one of it's parent directories.
URL::asset('assets/image.jpg');
You should be able to run php artisan cdn:sync public/assets --trim=public
before or during a deployment and once complete all files being called by URL::asset()
will return a CDN resource
Upload to CDN
Using this method will make the container public, even if previously set as private. This is a known issue yet to be addressed.
OpenCloud::upload($container, $file, $name = null)
- $container - (string) Name of the container to upload into
- $file - (string / UploadedFile) Path to file, or instance of 'Symfony\Component\HttpFoundation\File\UploadedFile' as returned by Input::file()
- $name - (string) Optional file name to be used when saving the file to the CDN.
Example:
Route::post('/upload', function() { if(Input::hasFile('image')){ $file = OpenCloud::upload('my-container', Input::file('image')); } $cdnUrl = $file->PublicURL(); // Do something with $cdnUrl return Redirect::to('/upload'); });
Delete from CDN
OpenCloud::delete($container, $file)