2017 © Pedro Peláez
 

yii2-extension yii2-filestorage-db

Extension for file uploading and attaching to the models

image

ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  • Saturday, July 7, 2018
  • by Ozerich
  • Repository
  • 2 Watchers
  • 2 Stars
  • 26 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 11 Versions
  • 63 % Grown

The README.md

Installation

The preferred way to install this extension is through composer., (*1)

Either run, (*2)

php composer.phar require ozerich/yii2-filestorage-db "*"

or add, (*3)

"ozerich/yii2-filestorage-db": "*"

to the require section of your composer.json file., (*4)

Add component configuration to your config.php, (*5)

    'components' => [
        'media' => [
            'class' => 'ozerich\filestorage\FileStorage',
            'scenarios' => [
                'avatar' => [
                    'storage' => [
                        'type' => 'file',
                        'saveOriginalFilename' => false,
                        'uploadDirPath' => __DIR__ . '/../../web/uploads/avatars',
                        'uploadDirUrl' => '/uploads/avatars',
                    ],
                    'validator' => [
                        'maxSize' => 2 * 1024 * 1024,     // 2 MB
                        'checkExtensionByMimeType' => true,
                        'extensions' => ['jpg', 'jpeg', 'bmp', 'gif', 'png']
                    ],
                    'thumbnails' => [
                        [
                            'width' => 500
                        ],
                        [
                            'height' => 500
                        ],
                        [
                            'alias' => 'preview',
                            'width' => 250,
                            'сrop' => true,
                            '2x' => true,
                            'force' => true,
                            'webp' => true
                        ],
                        [
                            'width' => 200,
                            'height' => 200,
                            'exact' => true
                        ],
                    ],
                    'quality' => 75
                ],
                'document' => [
                    'storage' => [
                        'type' => 'file',
                        'uploadDirPath' => __DIR__ . '/../../web/uploads/documents',
                        'uploadDirUrl' => '/uploads/documents',
                    ],
                    'validator' => [
                        'maxSize' => 20 * 1024 * 1024,      // 20 MB
                        'checkExtensionByMimeType' => true,
                        'extensions' => ['pdf', 'doc'],
                    ],
                ]
            ]
        ]
    ]

Add media component to bootstrap, (*6)

    'config' => [
        'bootstrap' => [..., 'media'],
    ]

Add migrations path to your console config (console.php), (*7)

    'config' => [
        'controllerMap' => [
            'migrate' => [
                'class' => 'yii\console\controllers\MigrateController',
                'migrationNamespaces' => [
                    'ozerich\filestorage\migrations',
                ],
            ],
        ],
    ]

Apply migrations, (*8)

php yii migrate/up

Usage

Example usage (get file from HTTP request):, (*9)

    /* app\controllers\UploadController.php */

    public function actionImage()
    {
        Yii::$app->response->format = 'json';
        $file = UploadedFile::getInstanceByName('file');

        $model = Yii::$app->media->createFileByUploadedFile($file, 'avatar');

        return [
            'image' => $model->toJSON()
        ];
    }

Output will be:, (*10)

    {
        "id": 1,
        "url": "http://localhost/uploads/images/W7/LK/W7LK3u5LJ7LGtc0nlGOqinl_AVZlinQH.jpg",
        "name": "test-file.jpg",
        "ext": "jpg",
        "mime": "image/jpeg",
        "size": 64749,
        "thumbnails": [
            {
                "id": "1_ORIGINAL",
                "thumb": "ORIGINAL",
                "width": 450,
                "height": 800,
                "url": "http://localhost/uploads/images/W7/LK/W7LK3u5LJ7LGtc0nlGOqinl_AVZlinQH.jpg",
                "url@2x": null
            },
            {
                 "id": "1_500xAUTO",
                 "thumb": "500xAUTO",
                 "width": 500,
                 "height": 200,
                 "url": "http://localhost/uploads/images/W7/LK/W7LK3u5LJ7LGtc0nlGOqinl_AVZlinQH_500_AUTO.jpg",
                 "url@2x": null
            },
            {
                 "id": "1_AUTOx500",
                 "thumb": "AUTOx500",
                 "width": 260,
                 "height": 500,
                 "url": "http://localhost/uploads/images/W7/LK/W7LK3u5LJ7LGtc0nlGOqinl_AVZlinQH_AUTO_500.jpg",
                 "url@2x": null
            },
            {
                 "id": "1_200x200",
                 "thumb": "200x200",
                 "width": 200,
                 "height": 200,
                 "url": "http://localhost/uploads/images/W7/LK/W7LK3u5LJ7LGtc0nlGOqinl_AVZlinQH_200_200.jpg",
                 "url@2x": "http://localhost/uploads/images/W7/LK/W7LK3u5LJ7LGtc0nlGOqinl_AVZlinQH_200_200@2x.jpg"
            }
        ]
    }

Example usage (load file from url):, (*11)

    /* app\models\User.php */

    public function setUserAvatarFromUrl($image_url)
    {
       $image = $media->createFileFromUrl($image_url, 'avatar');
       $this->avatar_image_id = $image->id;
    }

Example usage (load file from base64string):, (*12)

    /* app\controllers\UploadController.php */

    public function actionImage()
    {
        Yii::$app->response->format = 'json';
        $base64string = Yii::$app->request->post('data');
        $filename = Yii::$app->request->post('filename');

        $model = Yii::$app->media->createFileFromBase64($base64string, $filename, 'avatar');

        return [
            'image' => $model->toJSON()
        ];
    }

Console commands

To use console commands you should create a file FilestorageController.php at your commands folders., (*13)

<?php

namespace app\commands;

class FilestorageController extends \ozerich\filestorage\console\FilestorageController
{
    // className of your File model
    public $modelClass = 'app\models\Image';
}

If you did not use console commands at your projects, don't forget to confugure them, you should insert code in your config/console.php, (*14)

    'controllerNamespace' => 'app\commands',

List of commands:, (*15)

  1. php yii filestorage/fix-thumbnails - Regenerate thumbnails of all images

The Versions

07/07 2018

dev-master

9999999-dev https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

07/07 2018

0.5

0.5.0.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

07/07 2018

0.6

0.6.0.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

06/06 2018

0.4.2

0.4.2.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

29/03 2018

0.4.1

0.4.1.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

29/03 2018

0.4

0.4.0.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

29/03 2018

0.3.2

0.3.2.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

26/03 2018

0.3.1

0.3.1.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

25/03 2018

0.3

0.3.0.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

25/03 2018

0.2

0.2.0.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment

25/03 2018

0.1

0.1.0.0 https://github.com/Ozerich/yii2-filestorage-db

Extension for file uploading and attaching to the models

  Sources   Download

MIT

The Requires

 

file extension yii2 upload storage db attachment