This Laravel 5.1 package can associate all sorts of files with Eloquent models. It provides a simple API to work with. Here's an example:
$newsItem = News::find(1);
$newsItem->addMedia($pathToFile)->toCollection('images');
It can handle your uploads directly:
$newsItem->addMedia($request->file('image'))->toCollection('images');
Want to store some large files on another filesystem? No problem:
$newsItem->addMedia($smallFile)->toCollectionOnDisk('downloads', 'local');
$newsItem->addMedia($bigFile)->toCollectionOnDisk('downloads', 's3');
The storage of the files is handled by Laravel's Filesystem, so you can use any filesystem you like. Additionally the package can create image manipulations on images and pdfs that have been added in the medialibrary.
Spatie is a webdesign agency in Antwerp, Belgium. You'll find an overview of all our open source projects on our website.
You'll find the documentation on medialibrary.spatie.be.
Find yourself stuck using the package? Found a bug? Do you have general questions or suggestions for improving the media library? Feel free to create an issue on GitHub, we'll try to address it as soon as possible.
If you've found a bug regarding security please mail [email protected] instead of using the issue tracker.
To create derived images GD should be installed on your server. For the creation of thumbnails of pdf's you should also install Imagick.
On Ubuntu you can install Imagick by issuing this command:
sudo apt-get install imagemagick php5-imagick
You can install this package via composer using this command:
composer require spatie/laravel-medialibrary
Next, you must install the service provider:
// config/app.php
'providers' => [
...
Spatie\MediaLibrary\MediaLibraryServiceProvider::class,
];
You can publish the migration with:
php artisan vendor:publish --provider="Spatie\MediaLibrary\MediaLibraryServiceProvider" --tag="migrations"
After the migration has been published you can create the media-table by running the migrations:
php artisan migrate
You can publish the config-file with:
php artisan vendor:publish --provider="Spatie\MediaLibrary\MediaLibraryServiceProvider" --tag="config"
This is the contents of the published config file:
return [
/*
* The filesystems on which to store added files and derived images. Choose one or more
* of the filesystems you configured in app/config/filesystems.php
*/
'defaultFilesystem' => 'media',
/*
* The maximum file size of an item in bytes. Adding a file
* that is larger will result in an exception.
*/
'max_file_size' => 1024 * 1024 * 10,
/*
* This queue will used to generate derived images.
* Leave empty to use the default queue.
*/
'queue_name' => '',
's3' => [
/*
* The domain that should be prepended when generating urls.
*/
'domain' => 'https://xxxxxxx.s3.amazonaws.com',
],
];
And finally you should add a disk to app/config/filesystems.php
. This would be a typical configuration:
...
'disks' => [
'media' => [
'driver' => 'local',
'root' => public_path().'/media',
],
...
All files of the medialibrary will be stored on that disk. If you are planning on working with the image manipulations you should configure a queue on your service with the name specified in the config file.
You can run the tests with:
vendor/bin/phpunit
##Upgrading
Please see UPGRADING for details.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
Spatie is a webdesign agency in Antwerp, Belgium. You'll find an overview of all our open source projects on our website.
The MIT License (MIT). Please see License File for more information.