- it can handle all of your needs to manage you application media.
- it provides an API to make life easy for the consumers (client side devs).
- it will help the client side devs to make an reusable component for the media uploads.
- if you are creating an back-end system and your whole APIs are using json, you still not have a need to use base64 for you media.
- generate a temp path for the your uploaded file by using the exposed API for uploading media.
- upload the file in this temp path on the configured storage.
- return the base url of you storage and the temp path.
- so this file is exist in the temp path but till now nothing has used it (it's still temp file).
- but client side developers can preview it using the base url and the temp path.
- then you can relate this file to any model in you application.
- using this event (Elgndy\FileUploader\Events\UploadableModelHasCreated)
- the temp path is the place we use to hold the media in the early stage.
- it contains 4 parts.
- the temp folder (you can configure it).
- the related model.
- the type of this media (you can custom your own types).
- the file name.
- the real path is the final place for this file.
- it contains 4 parts.
- the related model.
- the related id.
- the type of this media.
- the filen name.
- API for uploading
- URL /upload-media
- METHOD post.
- HEADER (content type: multipart/encrypted)
- BODY (model: string, mediaType: string, media: file)
composer require alaaelgndy/file-uploader
- configure your models namespace like (App\)
- configure your temp path, the default is (temp/).
- update your models to implement (Elgndy\FileUploader\Contracts\FileUploaderInterface).
- use Uploadable trait in your uploadable models.
- implement this function getMediaTypesWithItsOwnValidationRules()
- the keys are the mediaType
- the values are the available extensions for this specefic mediaType.
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use Elgndy\FileUploader\Contracts\FileUploaderInterface;
use Elgndy\FileUploader\Traits\Uploadable;
class User extends Model implements FileUploaderInterface
{
use Uploadable;
public function getMediaTypesWithItsOwnValidationRules(): array
{
return [
'images' => [
'png',
'jpg',
'jpeg',
],
'national_id' => [
'pdf'
],
'logos' => [
'png'
]
];
}
}
- after these points now you can let the client side call our API anytime to create temp files.
- first write your own business logic to create the record and after creating it, fire this event (UploadableMediaHasCreated) and pass your created record which is type of Model, and the temp path.
- by using this event it will remove the relation from database and remove the folder from the FS. (UploadableMediaHasDeleted) and pass your deleted record which is type of Model. that's it :).
- the Uploadable trait has these functions.
- media() returns collection of related media.
- getMedia(...$types) returns collection of related media with specific types.
- mediaCount(...$types) returns integer of the count rely on your passed types.
- custom image attribute will get the first media always (take care of this point).
- users/
- userId/
- images/
- logos/
- national_id/
- userId/
- enhance the readme file.
- increase the unit test coverage.
- adding resizing files feature.
- add more example of use.
- create custom response for the api in exceptions case.
- create command to clear the useless data in temp folder.
- add versioning and changelog file.
- test it on laravel 5.6 or greater versions (using CI).
- configure the upload route.
- the ability of assign middlewares to the upload route.
- add feature test to the API.
- translate the exceptions.
- use directory seperator constants instead of '/'.
- move array of files at once.
- add event to upload and move at once.