robtrehy / laravel-user-preferences
A package for Laravel to store user preferences for your project.
Installs: 5 050
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 2
Open Issues: 0
pkg:composer/robtrehy/laravel-user-preferences
Requires
- php: ^8.1
- laravel/framework: ^10.0|^11.0|^12.0
Requires (Dev)
- nunomaduro/collision: ^7.0|^8.0
- orchestra/testbench: ^8.20|^9.0|^10.2
- phpunit/phpunit: ^10.5|^11.0|^12.0
- squizlabs/php_codesniffer: ^3.6|^3.7
README
This is a package for Laravel that can be used to store and access preferences of the currently authenticated user.
The preferences are stored as JSON in a single database column. The default configuration stores this alongside the user record in
the users table.
Installation
- Run
composer require robtrehy/laravel-user-preferencesto include this in your project. - Publish the config file with the following command
php artisan vendor:publish --provider="RobTrehy\LaravelUserPreferences\UserPreferencesServiceProvider" --tag="config" - Modify the published configuration file to your requirements. The file is located at
config/user-preferences.php. - Add the
preferencescolumn to the database. A migration file is included, just run the following command
This will add the column defined in your configuration file to the table defined in your configuration file.php artisan vendor:publish --provider="RobTrehy\LaravelUserPreferences\UserPreferencesServiceProvider" --tag="migrations" && php artisan migrate
Configuration
Open config/user-preferences.php to adjust the package's configuration.
If this file doesn't exist, run
php artisan vendor:publish --provider="RobTrehy\LaravelUserPreferences\UserPreferencesServiceProvider" --tag="config"
to create the default configuration file.
Set table, column, and primary_key to match your requirements. primary_key should be the users id.
Laravel User Preferences uses the Laravel Cache driver to reduce the number of queries on your database. By default Laravel caches using the file driver. If you wish to disable this, you can use the null driver.
The cache key supplied by Laravel User Preferences adds a prefix and suffix to the user's id. You can supply your own prefix and suffix by changing the cache.prefix and cache.suffix configuration values.
In the defaults array you can set your default values for user preferences.
Example configuration
'database' => [
'table' => 'users',
'column' => 'preferences',
'primary_key' => 'id'
],
'cache' => [
'prefix' => 'user-',
'suffix' => '-preferences',
],
'defaults' => [
'theme' => 'blue',
'show_welcome' => true
]
Usage
Set a preference
Use this method to set a preference for the currently authenticated user:
UserPreferences::set(string $setting, $value);
Get a preference
Get the value of a preference for the currently authenticated user:
UserPreferences::get(string $setting);
Reset a preference
Reset a single preference for the currently authenticated user:
UserPreferences::reset(string $setting);
Reset all default preferences
Reset all default preferences for the currently authenticated user:
UserPreferences::setDefaultPreferences();
Get all preferences
Get all preferences for the currently authenticated user:
UserPreferences::all();
Check if a preference exists
Check if the currently authenticated user has a specific preference:
UserPreferences::has(string $setting);
Save a preference
All preferences are saved automatically when UserPreferences::set() is called.
New: Arbitrary User Methods
You can now work with preferences for any user instance or ID, not just the currently authenticated user.
Get a preference for a specific user
UserPreferences::getForUser(string $setting, User|int $user);
$usercan be aUsermodel instance or a user ID.- Returns the preference value if set, otherwise the default.
Set a preference for a specific user
UserPreferences::setForUser(string $setting, $value, User|int $user);
$usercan be aUsermodel instance or a user ID.- Saves the preference for that user without affecting the currently authenticated user.
Reset a preference for a specific user
UserPreferences::resetForUser(string $setting, User|int $user);
- Returns
trueif the default was restored,falseif the preference was deleted.
Check if a specific user has a preference
UserPreferences::hasForUser(string $setting, User|int $user);
- Returns
trueif a value exists,falseotherwise.
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
License
This Laravel package is free software distributed under the terms of the MIT license. See LICENSE