insolita/yii2-multifs

Multifs Manager based on (League\Flysystem\MountManager) for work with set of filesystems.

Installs: 3

Dependents: 0

Suggesters: 0

Security: 0

Stars: 3

Watchers: 3

Forks: 0

Open Issues: 0

Type:yii2-extension

1.0.0 2017-11-03 19:05 UTC

This package is auto-updated.

Last update: 2024-03-29 03:44:28 UTC


README

  • Provide Multifs Manager based on (League\Flysystem\MountManager) for work with set of filesystems (League\Flysystem\Filesystem);
  • Provide flexible Uploader service with support different strategies for resolve file naming, file path structure, and file saving
  • Provide sample Upload,View and Delete Actions with output compatible with trntv\filekit\widget\Upload

Status

Installation

The preferred way to install this extension is through composer.

Either run

composer require --prefer-dist insolita/yii2-multifs "~1.0.0"

or add

"insolita/yii2-multifs": "~0.0.1"

to the require section of your composer.json file.

Usage

Once the extension is installed, simply use it in your code by :

Define in bootstrap neccessary filesystems

 $avatars = (new \insolita\multifs\builders\LocalFsBuilder('@app/web/uploads/avatars'))->build();
 $covers = (new \insolita\multifs\builders\LocalFsBuilder('@app/web/uploads/covers'))->build();
 $attach = (new \insolita\multifs\builders\LocalFsBuilder('@app/web/uploads/attach'))->build();
 $data = (new \insolita\multifs\builders\LocalFsBuilder('@data'))->build();

(Ensure that aliases already defined)

Register in container:

 \insolita\multifs\contracts\IMultifsManager::class                                              => [
                \insolita\multifs\MultiFsManager::class,
                [
                    [
                        'avatars'  => $avatars,
                        'covers'   => $covers,
                        'attach'   => $attach,
                        'internal' => $data,
                    ],
                ],
            ],
            \insolita\multifs\contracts\IUploader::class=>[
                \insolita\multifs\Uploader::class,
                [
                    \yii\di\Instance::of(\insolita\multifs\contracts\IMultifsManager::class),
                    'attach'
                ]
            ],

also you can add components aliases

'components'=>[
   'multifs'=>\insolita\multifs\contracts\IMultifsManager::class,
   'uploader'=>\insolita\multifs\contracts\IUploader::class,
]

On fly usage

    echo Yii::$app->multifs->listPrefixes();
    Yii::$app->multifs->mountFilesystem('special', new Filesystem(new Adapter(...)));
    Yii::$app->multifs->write('special://some/file/path/name.txt','Hello Test');
    $fs = Yii::$app->multifs->getFilesystem('internal');
    Vardumper::dump($fs->listConents('',true));

Uploader

   $file = \yii\web\UploadedFile::getInstanceByName('file');
   $path = Yii::$app->uploader->setFsPrefix('avatars')
             ->setFileNameStrategy(new insolita\multifs\strategy\filename\AsIsStrategy())
             ->setFilePathStrategy(new insolita\multifs\strategy\filename\NameHashStrategy())
             ->setFileSaveStrategy(new insolita\multifs\strategy\filename\ExceptionSaveExistsStrategy())
             ->save($file);

  \Yii::$app->response->sendStreamAsFile(Yii::$app->multifs->readStream($path),
                                          pathinfo($path, PATHINFO_BASENAME),
                                          [
                                             'mimeType' => $file->getType(),
                                             'inline'=>true
                                          ]);

Other documentation will be later; see tests