ed-smartass / yii2-settings
Dynamic setting for Yii2 application
Installs: 52
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Type:yii2-extension
Requires
- yiisoft/yii2: ~2.0.14
This package is auto-updated.
Last update: 2024-12-25 23:49:49 UTC
README
Installation
- Install via composer
composer require ed-smartass/yii2-settings
- Apply migrations
php yii migrate --migrationPath=@vendor/ed-smartass/yii2-settings/src/migrations
Or add to console config
return [ // ... 'controllerMap' => [ // ... 'migrate' => [ 'class' => 'yii\console\controllers\MigrateController', 'migrationPath' => [ '@console/migrations', // Default migration folder '@vendor/ed-smartass/yii2-settings/src/migrations' ] ] // ... ] // ... ];
- Config application
return [ // ... 'bootstrap' => [ // ... 'settings' ], 'components' => [ // ... 'settings' => [ 'class' => 'Smartass\Yii2Settings\Settings', // Name of table with settings. Default: `{{%setting}}`. 'table' => '{{%setting}}', // ID of db commponent in application. Default: `db`. 'dbComponent' => 'db', // If you want to cache setting. Default: `false`. 'cache' => true, // ID of cache commponent in application. Default: `cache`. 'cacheComponent' => 'cache', // Key for storing settings in cache. Default: `settings`. 'cacheKey' => 'settings', // Cache duration for settings. Default: `null`. 'cacheDuration' => null, // If you want to change Application config set to `true` // and set value at config like `'language' => '%main.language|ru%'`. // Where: `main.language` is setting name and `ru` is default value // Default: `false`. 'processConfig' => false, ] ] // ... ];
Usage
// List all settings Yii::$app->settings->settings // Get setting Yii::$app->settings->get('access_token_ttl'); // Or Yii::$app->settings->access_token_ttl; // Set setting Yii::$app->settings->set('access_token_ttl', 3600*24*7); // Or Yii::$app->settings->access_token_ttl = 3600*24*7; // Only if setting `access_token_ttl` already exist
Methods
-
get($key, $default = null, $saveDefault = false) — get setting by key
- $key — key of setting
- $default — default value if setting does not exist
- $saveDefault — save default value if setting does not exist
-
set($key, $value, $type = null) — set setting
- $key — key of setting
- $value — value of setting (if value is
null
setting will be deleted) - $type — type of setting (
integer
,float
,string
,boolean
,array
), if type isnull
when type will be auto detected
-
delete($key) — delete setting by key
- $key — key of setting
-
flush() — deleting all settings