wearesho-team / yii2-filesystem
Yii2 integration for league/flysystem
Installs: 834
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 2
pkg:composer/wearesho-team/yii2-filesystem
Requires
- php: >=8.4
- ext-zip: *
- horat1us/yii2-environment-config: ^1.1
- league/flysystem: ^3.29
- league/flysystem-aws-s3-v3: ^3.23
- yiisoft/yii2: ^2.0.40
Requires (Dev)
- horat1us/yii2-asset-free: ^1.0
- mockery/mockery: ^1.5
- phpunit/phpunit: ^9.5
- squizlabs/php_codesniffer: ^3.13
README
Integration of league/flysystem for Yii2.
It is configured by environment variables by default. Available integration out-of-box:
Configuring
By-default configuring available using environment variables. To choose which integration to use you need to configure FILESYSTEM_ADAPTER variable. Available values: local, s3. (or another, if you use custom bootstrap configuration)
Configuring S3 adapter
Variable | Required | Default | Description |
---|---|---|---|
S3_ENDPOINT | yes | endpoint url (with http/https) | |
S3_REGION | yes | Example: eu-central-1 | |
S3_BUCKET | yes | Example: yourcompany | |
S3_PREFIX | no | empty string | path prefix |
Configuring Local adapter
Variable | Required | Default | Description |
---|---|---|---|
FILESYSTEM_LOCAL_SAVE_PATH | yes | path to save file on local machine |
Usage
Bootstrap
To start use this package out-of-box you need to append Bootstrap into your Yii2 application.
<?php // common/config/main.php or another configuration file use Wearesho\Yii\Filesystem; return [ 'components' => [ // ... ], 'bootstrap' => [ 'class' => Filesystem\Bootstrap::class, 'container' => true, // if you need to configure global DI container (\Yii::$container) 'id' => 'fs', // \Yii::$app component to be configured. Filesystem will be available using \Yii::$app->fs ], ];
Note: for advanced usage you may customize Bootstrap adapters and config properties
TODO
- Tests