Use qcod/laravel-settings
to store key value pair settings in the database.
All the settings saved in db is cached to improve performance by reducing sql query to zero.
1 - You can install the package via composer:
$ composer require qcod/laravel-settings
2 - If you are installing on Laravel 5.4 or lower you will be needed to manually register Service Provider by adding it in config/app.php
providers array and Facade in aliases arrays.
'providers' => [
//...
QCod\Settings\SettingsServiceProvider::class
]
'aliases' => [
//...
"Settings" => QCod\Settings\Facade::class
]
In Laravel 5.5 or above the service provider automatically get registered and a facade Setting::get('app_name')
will be available.
3 - Now run the migration by php artisan migrate
to create the settings table.
Optionally you can publish migration by running
php artisan vendor:publish --provider="QCod\Settings\SettingsServiceProvider" --tag="migrations"
You can use helper function settings('app_name')
or Settings::get('app_name')
to use laravel settings.
// Pass `true` to ignore cached settings
settings()->all($fresh = false);
// Get a single setting
settings()->get($key, $defautl = null);
// Set a single setting
settings()->set($key, $value);
// Set a multiple settings
settings()->set([
'app_name' => 'QCode',
'app_email' => '[email protected]',
'app_type' => 'SaaS'
]);
// check for setting key
settings()->has($key);
// remove a setting
settings()->remove($key);
Please see CHANGELOG for more information on what has changed recently.
The package contains some integration/smoke tests, set up with Orchestra. The tests can be run via phpunit.
$ composer test
Please see CONTRIBUTING for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
QCode.in (https://www.qcode.in) is blog by Saqueib which covers All about Full Stack Web Development.
The MIT License (MIT). Please see License File for more information.