vluzrmos / eloquent-settings by vluzrmos

An Eloquent Settings Repository
60
3
3
Package Data
Maintainer Username: vluzrmos
Maintainer Contact: vluzrmos@gmail.com (Vagner do Carmo)
Package Create Date: 2015-12-29
Package Last Update: 2019-05-14
Language: PHP
License: MIT
Last Refreshed: 2024-12-29 15:11:28
Package Statistics
Total Downloads: 60
Monthly Downloads: 0
Daily Downloads: 0
Total Stars: 3
Total Watchers: 3
Total Forks: 1
Total Open Issues: 0

Eloquent Settings Repository

A package to store settings of your application on database.

Installation

composer require vluzrmos/eloquent-settings

Configuration

First, you have to add the service provider in your config/app.php providers list:

'providers' => [
    ...
    \Vluzrmos\EloquentSettings\Providers\EloquentSettingsServiceProvider::class,
],

Second, you have to publish the configs and migrations:

php artisan vendor:publish --provider=Vluzrmos\EloquentSettings\Providers\EloquentSettingsServiceProvider

Third, run the migrations:

php artisan migrate

Usage

You can use the dependencie injection or the setting helper:

use \Vluzrmos\EloquentSettings\Setting;

class YourInjectableClass {
   
   protected $settings;
   
   public function __construct (Setting $settings) {
       $this->settings = $settings;   
   }
   
   public function theMethod() {
       $option = $this->settings->get('my.awesome.option', 'default-value');
   }
} 
    

It's more easy to use the setting helper:

// Getter
$option = setting('my.awesome.option', 'default-value');
//or
$option = setting()->get('my.awesome.option', 'default-value');

// Setter
setting()->set('my.awesome.option', 'That is Awesome!');

setting()->save(); //remember, without this the settings will not be stored on database

Setting API

get(string key, mixed default=null) : mixed - Get a setting on database, if doens't exists it will use the default value.

set(string|array key, mixed value=null) : void - Set a value or array of key=>values to the settings.

forget(string key) : void - Clear an value of the settings.

has(string key) : bool - Check if settings has a given key.

all() : array - Get an array of all settings.

except(string|array keys ...) : array - Get settings which doesn't match with that given keys.

only(string|array keys ...) : array - Get settings which match with that given keys.

save() : void - IMPORTANT! Store settings on the database.

update(string|array keys, mixed value=null) : void - Sets and saves one or more settings.