Skip to content

Store additional config files in JSON, DB, or any other format. Write, Read.

License

Notifications You must be signed in to change notification settings

garf/laravel-conf

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

84 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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.

About

Store additional config files in JSON, DB, or any other format. Write, Read.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages