App & Models Settings for Laravel
This package allows you to store application wide and model specific Laravel settings. Settings values are type-cast and stored properly. You can also define your own casts and store repository.
Installation
Install the package via composer:
composer require smartisan/laravel-settings
Publish the config file with:
php artisan vendor:publish --provider="Smartisan\Settings\SettingsServiceProvider" --tag="config"
Publish the migration file with:
php artisan vendor:publish --provider="Smartisan\Settings\SettingsServiceProvider" --tag="migrations"
And finally run the migration with:
php artisan migrate
Usage
The package provides various APIs to access the settings manager. You can access it with Settings facade, settings() helper method and via HasSettings trait on your models.
Store Settings
You can set single entry, or multiple entries of settings. The values of objects will be cast according to the rules defined in settings.php config file.
- One Entry
Settings::set('key', 'value');
- Multiple Entries
You can set multiple settings entries by passing an associative array of keys and values. Casts will be applied on all the payload, even on nested arrays.
Settings::set([
'k1' => Carbon::now(),
'k2' => [
'k3' => $user,
'k4' => [
'k5' => $model
],
]
]);
- Specify Settings Group
It's possible to categorize your settings into groups by calling group method.
Settings::group('name')->set('key', 'value');
Settings::group('name')->set([
'k1' => 'v1',
'k2' => 'v2',
]);
- Model Specific Settings
It's also possible to set settings for a specific model by calling for method
Settings::for($model)->set('key', 'value');
Settings::for($model)->set([
'k1' => 'v1',
'k2' => 'v2',
]);
- Mixing Filters
You can mix all filters together like this:
Settings::for($model)->group('name')->set('key', 'value');
Retrieve Settings
You can retrieve one or multiple entries and specify the default value if not exist.
- One Entry
Settings::get('k1', 'default');
- Multiple Entries
If the entry key does not exist, the default value will be placed instead
Settings::get(['k1', 'k2', 'k3'], 'default');
- All Entries
If you want to retrieve all entries, you simply call all method. You can also specify the model or group. Also to excempt some specific keys.
Note: Remember that retrieving all entries without specifying the group or model, will retrieve all entries that has no group or model set. You can consider these as (global app settings).
Settings::all();
Settings::for($model)->all();
Settings::for($model)->group('name')->all();
Settings::except('k1', 'k2')->for($model)->group('name')->all();
Settings::except('k1')->for($model)->group('name')->all();
Forget Entry
You can remove entries by calling forget method.
Settings::forget('key');
Settings::for($model)->group('name')->forget('key');
Determine Existance
You can determine whether the given settings entry key exists or not
Settings::exist('key');
Settings::for($model)->exist('key');
Settings::for($model)->group('name')->exist('key');
Helper Method
The package also ships with a settings helper method, you can use it instead of using Settings Facade
settings()->set('key', 'value');
...
HasSettings Trait
You can use HasSettings trait on your Eloquent models as well
- First prepare your model
use Smartisan\Settings\HasSettings;
class User extends Model
{
use HasSettings;
}
- Now you can call settings() method on that model. This is equivelant to
Settings::for($model)
$user->settings()->set('k1', 'v1');
...
Custom Repositories
If you don't want to use the database repository, you can easily create your own settings repository. To do that
- Create a class of your repository that implements Repository interface and implement the following methods
use Smartisan\Settings\Contracts\Repository;
class FileRepository implements Repository
{
public function get($key,$default = null) {
//
}
public function set($key,$value = null) {
//
}
public function forget($key) {
//
}
public function all() {
//
}
}
- In settings configuration file, add your own repository config to repositories attribute
'repositories' => [
...
'file' => [
...
]
],
- Change the default repository in settings config file to your own repository implementation
Custom Casts
The package allows you to easily create your own casting rules of any object type.
- Create your own cast class that implements Castable interface.
Note: The set method is called when the value of the entries is being stored to the repository, and the get method is called when the value is being retrieved from the repository.
use Smartisan\Settings\Contracts\Castable;
class CustomCast implements Castable
{
public function set($payload) {
//
}
public function get($payload) {
//
}
}
- Add the casts to the array of casts in settings config file
'casts' => [
...
CustomDataType::class => CustomCast::class
]
Note: If you want to pass a parameter to your cast, you can set an object of the cast instead of cast class name
'casts' => [
...
CustomDataType::class => new CustomCast('param')
]
Settings Cache
You can easily enable or disable caching settings in settings.php config file. You can also specify which caching store to use
'cache' => [
'enabled' => env('SETTINGS_CACHE_ENABLED', false),
'store' => null,
'prefix' => null,
],
Testing
To run the package's tests, simply call the following command
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
Alternatives
License
The MIT License (MIT). Please see License File for more information.