padosoft / laravel-uploadable by lopadova

Laravel package for automatic upload handling with trait
6,812
28
6
Package Data
Maintainer Username: lopadova
Maintainer Contact: helpdesk@padosoft.com (Lorenzo Padovani)
Package Create Date: 2016-08-14
Package Last Update: 2024-06-21
Language: PHP
License: MIT
Last Refreshed: 2025-01-10 15:19:18
Package Statistics
Total Downloads: 6,812
Monthly Downloads: 169
Daily Downloads: 8
Total Stars: 28
Total Watchers: 6
Total Forks: 4
Total Open Issues: 1

Auto upload handling with Eloquent models trait

Latest Version on Packagist Software License Build Status Quality Score Total Downloads SensioLabsInsight

This package provides a trait that will automatic handlind upload when saving/updating/deleting any Eloquent model with upload form request.

##Requires

  • php: >=7.0.0
  • illuminate/database: ^5.7
  • illuminate/support: ^5.7
  • illuminate/http: ^5.7
  • padosoft/laravel-request: ^2.0
  • padosoft/io: ^1.0
  • padosoft/support: ^2.0

Installation

You can install the package via composer:

$ composer require padosoft/laravel-uploadable

Usage

Your Eloquent models should use the Padosoft\Uploadable\Uploadable trait and the Padosoft\Uploadable\UploadOptions class.

You can define getUploadOptions() method in your model.

Here's an example of how to implement the trait with implementation of getUploadOptions():

<?php

namespace App;

use Padosoft\Uploadable\Uploadable;
use Padosoft\Uploadable\UploadOptions;
use Illuminate\Database\Eloquent\Model;

class YourEloquentModel extends Model
{
    use Uploadable;
    
 /**
     * Retrive a specifice UploadOptions for this model, or return default UploadOptions
     * @return UploadOptions
     */
    public function getUploadOptions() : UploadOptions
    {
        if($this->uploadOptions){
            return $this->uploadOptions;
        }

        $this->uploadOptions = UploadOptions::create()->getUploadOptionsDefault()
            ->setUploadBasePath(public_path('upload/' . $this->getTable()))
            ->setUploadsAttributes(['image', 'image_mobile']);

        return $this->uploadOptions;
    }
}

You can specified uploads attributes with:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setUploadsAttributes(['image', 'image_mobile']);
}

You can set the base upload path for your model:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setUploadBasePath(public_path('upload/news'));
}

You can set different path for each (or for some) upload attributes in your model:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setUploadPaths(['image_mobile' => '/mobile' ]);
}

It support validation to accept files by specified list of Mime Type:

public function getUploadOptions() : UploadOptions
{
    return UploadOptions::create()
        ->setMimeType([
          'image/gif',
          'image/jpeg',
          'image/png',
            ]);
}

By default every uploaded file will rename with 'original_name_'.$model->id.'.original_ext' but you can redefine a custom function for renaming file:

/**
 * Generate a new file name for uploaded file.
 * Return empty string if $uploadedFile is null.
 * @param \Illuminate\Http\UploadedFile $uploadedFile
 * @param String $uploadField
 * @return string
 */
public function generateNewUploadFileName(\Illuminate\Http\UploadedFile $uploadedFile, string $uploadField) : string 
{
    if($uploadField=='image'){
        return 'pippo.jpg';
    }else{
        return 'pippo_mobile.jpg';
    }
}

For all options see UploadOptions class.

Change log

Please see CHANGELOG for more information what has changed recently.

Testing

$ composer test

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email instead of using the issue tracker.

Credits

About Padosoft

Padosoft (https://www.padosoft.com) is a software house based in Florence, Italy. Specialized in E-commerce and web sites.

License

The MIT License (MIT). Please see License File for more information.