garf / laravel-conf by garf

Store additional configs in JSON or Database (write, read)
6,137
25
4
Package Data
Maintainer Username: garf
Maintainer Contact: garipov.dinar@gmail.com (Dinar Garipov)
Package Create Date: 2015-07-22
Package Last Update: 2016-11-14
Home Page:
Language: PHP
License: MIT
Last Refreshed: 2024-04-17 15:01:59
Package Statistics
Total Downloads: 6,137
Monthly Downloads: 9
Daily Downloads: 0
Total Stars: 25
Total Watchers: 4
Total Forks: 4
Total Open Issues: 1

Laravel Improved Config

Software License Laravel Version

Laravel Conf

Russian Documentation / Русская документация

Custom editable configs for Laravel 5.

Caution

Repository address changed from gaaarfild to garf. Dont forget to fix your composer.json.

This package helps you to store your additional configuration from your code in custom storage.

By default it uses JSON-file.

This is helpful when you need to edit your configuration by user from GUI. i.e. Website settings.

Caution!

Be careful! This is version 2 of the package and fallback configuration was removed.

If you still need to use it, please install version 1.*

Install

To install version 2, type the following command in your command line:

$ composer require "garf/laravel-conf:3.*"

Or add

"garf/laravel-conf": "3.*"

to your composer.json file into require section.

Then type in console

$ composer update

When update completed, add to your config/app.conf file to providers section

'providers' => [
    // ...
    Garf\LaravelConf\LaravelConfServiceProvider::class,
]

If you want to use Conf facade, add to same file at the aliases section

'aliases' => [
    // ...
  'Conf' => Garf\LaravelConf\ConfFacade::class,
]

Publishing config file

To be able to change file location, please execute the following command in the console:

php artisan vendor:publish --provider="Garf\LaravelConf\LaravelConfServiceProvider" --tag="config"

Then you can edit file config/laravel-conf.php to set any path to file you want to.

Usage

Get config value

Conf::get('key.to.retrieve', 'default_value');

Else will return default value.

Could be used 'dot' notation

Save config value

Conf::set('key', 'value_to_save');

Could be used 'dot' notation

Also method put can be used to store multiple config values as array

$config = [
    'key1' => 'value1',
    'key2.subkey' => `value2`,
];
Conf::put($config);

Removing key from config

Conf::forget('key');

Could be used 'dot' notation

Get entire config

Conf::all();

Get entire config in JSON

Conf::toJson();

Check config key existence

Conf::has('key.to.check');

Could be used 'dot' notation

Helper

Also helper conf() can be used for more convenience.

Usage is similar to build in config() helper.

conf()->set('key.subkey', 'myValue');

conf('key.subkey') // will return 'myValue'

conf('non.existing.key', 'myDefaultValue') // will return 'myDefaultValue'

$config = [
    'key1' => 'value1',
    'key2.subkey' => `value2`,
];

conf($config)

Custom storage drivers

This package uses the Laravel Manager class under the hood, so it's easy to add your own custom store driver if you want to store in some other way. All you need to do is extend the abstract Garf\LaravelConf\Drivers\AbstractDriver class, implement the abstract methods and call Conf::extend.

class MyStorageDriver extends Garf\LaravelConf\Drivers\AbstractDriver {
    // ...
}
Conf::extend('mystorage', function($app) {
    return $app->make('MyStorageDriver');
});

Contributions

Contributions are highly appreciated.

Send your pull requests to master branch.

License

The MIT License (MIT). Please see License File for more information.