Download the PHP package ricardoboss/laravel-user-settings without Composer
On this page you can find all versions of the php package ricardoboss/laravel-user-settings. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download ricardoboss/laravel-user-settings
More information about ricardoboss/laravel-user-settings
Files in ricardoboss/laravel-user-settings
Package laravel-user-settings
Short Description Simple user settings facade for Laravel.
License MIT
Homepage https://github.com/ricardoboss/laravel-user-settings
Informations about the package laravel-user-settings
laravel-user-settings
Simple user settings facade for Laravel. Settings are stored as JSON in a single database column, so you can easily add it to an existing table (users
for example).
Installation
- Run
composer require ricardoboss/laravel-user-settings
to include this in your project. - Run
php artisan vendor:publish --provider="Grimthorr\LaravelUserSettings\ServiceProvider" --tag="config"
to publish the config file. - Modify the published configuration file located at
config/laravel-user-settings.php
to your liking. - Create a column in a table on your database to match the config in your settings file. Alternatively, use the Laravel migration included in this package to automatically create a
settings
column in theusers
table:php artisan vendor:publish --provider="Grimthorr\LaravelUserSettings\ServiceProvider" --tag="migrations" && php artisan migrate
.Attention: the datatype of your column should be large enough to store all your settings in JSON format. For MySQL,
TEXT
should be large enough.
Configuration
Pop open config/laravel-user-settings.php
to adjust package configuration. If this file doesn't exist, run php artisan vendor:publish --provider="Grimthorr\LaravelUserSettings\ServiceProvider" --tag="config"
to create the default configuration file.
Table
Specify the table on your database that you want to use.
Column
Specify the column in the above table that you want to store the settings JSON data in.
Constraint key
Specify the index column used for the constraint - this is used to differentiate between different users, objects or models (normally id).
Default constraint value
Specify the default constraint value - by default this will be the current user's ID, and will be superseded by specifying a $constraint_value
on any function call.
Custom constraint
Specify a where clause for each query - set this if you do not want to access different rows (for example if your app is single-user only).
Usage
Use the Setting facade (Setting::
) or the helper function (setting()->
) to access the methods in this package. The $constraint_value
parameter is optional on all functions; if this is not passed, the default_constraint_value
from the config file will be used.
Set
Use set
to change the value of a setting. If the setting does not exist, it will be created automatically. You can set multiple keys at once by passing an associative (key=>value) array to the first parameter.
Get
Use get
to retrieve the value of a setting. The second parameter is optional and can be used to specify a default value if the setting does not exist (the default default value is null
).
Forget
Unset or delete a setting by calling forget
.
Has
Check for the existence of a setting, returned as a boolean.
All
Retrieve all settings as an associative array (key=>value).
Save
Save all changes back to the database. This will need to be called after making changes; it is not automatic.
Load
Reload settings from the database. This is called automatically if settings have not been loaded before being accessed or mutated.
Example
These examples are using the default configuration.
Using the default constraint value
The following sets and returns the currently logged in user's setting "example".
Specify a constraint value
The following sets and returns the setting "example" for the user with id of 23.
Finally
Contributing
Feel free to create a fork and submit a pull request if you would like to contribute.
Bug reports
Raise an issue on GitHub if you notice something broken.
Credits
Forked from Grimthorr on https://github.com/Grimthorr/laravel-user-settings
Based loosely on https://github.com/anlutro/laravel-settings.
All versions of laravel-user-settings with dependencies
illuminate/support Version ^8.0
illuminate/config Version ^8.0
illuminate/database Version ^8.0
ext-json Version *