thinhbuzz / laravel-setting by Mr.Buzz

Package changes config for laravel 5.*
1,097
1
2
Package Data
Maintainer Username: Mr.Buzz
Maintainer Contact: mr.thinhbuzz@gmail.com (ThinhBuzz)
Package Create Date: 2015-10-26
Package Last Update: 2017-07-11
Language: PHP
License: MIT
Last Refreshed: 2024-12-19 03:11:15
Package Statistics
Total Downloads: 1,097
Monthly Downloads: 0
Daily Downloads: 0
Total Stars: 1
Total Watchers: 2
Total Forks: 1
Total Open Issues: 0

Package changes config for laravel 5.*

Cài đặt

Mở file composer.json và thêm require:

{
    "require": {
        "buzz/laravel-setting": "1.*"
    }
}

Sau đó chạy lệnh composer update để cài đặt.

hoặc chạy command sau để tự động thêm vào composer.json và cài đặt:

composer require buzz/laravel-setting

Mở file config/app.php và thêm ServiceProvider.

'providers' => [
    //.....
    Illuminate\Validation\ValidationServiceProvider::class,
    Illuminate\View\ViewServiceProvider::class,
    //.....
    \Buzz\LaravelSettingServiceProvider::class,
],

Cấu hình

Tạo file cấu hình config/setting.php bằng lệnh sau:

php artisan vendor:publish --provider="Buzz\LaravelSettingServiceProvider"

hoặc

php artisan vendor:publish
setting.php
<?php
return [
    'path' => storage_path('settings.json'),//đường dẫn tới file `setting.json`, nên đặt ở `storage` hoặc `resources`
    'auto_alias' => true,//tự động tạo thêm alias `Setting`
    'auto_save' => true,//tự động save sau khi kết thúc request (sẽ không hoạt động nếu sử dụng `exit` hoặc `die`)
    'force_save' => false,//bắt buộc gọi save dù không thực hiện thao tác add, set, remove
    'system_cnf' => false,//get config của app nếu trong setting không tồn tại
];

Sử dụng

Thay đổi alias

Mặc định package sẽ thêm alias Setting và bạn chỉ việc sử dụng alias này, nếu bạn muốn thay đổi alias thì sửa 'auto_alias'=>false và thêm trong aliases của config/app.php

'aliases' => [
    //.....
    'Validator' => Illuminate\Support\Facades\Validator::class,
    'View'      => Illuminate\Support\Facades\View::class,
    //.....
    'YourAlias'      => \Buzz\LaravelSettingFacade::class,
],

Tắt tự động lưu

Mặc định package sẽ chỉ lưu khi kết thúc request và settings có thay đổi bất kì, nếu bạn muốn tắt chức năng này thì sửa 'auto_save' => true, và sau đó sử dụng Setting::save() (hoặc YourAlias::save() nếu bạn đã đổi alias). ***Lưu ý: tính năng tự động lưu sẽ không hoạt động nếu bạn dùng exit hoặc die function

Các hàm hỗ trợ

Setting::clean();//xóa tất cả settings
Setting::save($force = false);//Lưu tất cả các thay đổi
Setting::all();//Lấy ra tất cả settings
Setting::has($key);//kiểm tra sự tồn tại của setting theo key
Setting::get($key, $default = false, $system = false);//lấy giá trị theo key
Setting::setData($data);//ghi đè tất cả settings
Setting::add($key, $value);//thêm mới một setting
Setting::add([
    ['name' => 'name1', 'value' => 'value1'],
    ['name' => 'name2', 'value' => 'value2'],
    ['name' => 'name3', 'value' => 'value3'],
]);//thêm mới nhiều settings
Setting::remove($key);//xóa một setting theo key
Setting::remove([
    'name1',
    'name2',
    'name3',
]);//xóa nhiều settings theo key
Setting::set($key, $default);//cập nhật giá trị mới cho setting theo key
Setting::set([
    ['name' => 'name1', 'value' => 'value1'],
    ['name' => 'name2', 'value' => 'value2'],
    ['name' => 'name3', 'value' => 'value3'],
]);//cập nhật giá trị mới cho nhiều settings theo key
Setting::sync();//thêm tất cả config của app vào Setting
Setting::sync('mail');//thêm config của app vào Setting theo key
Setting::sync([
    'key1',
    'key2',
    'key3',
]);//Thêm nhiều config của app vào Setting theo key

Package sử dụng các array helpers của laravel, để biết cách sử dụng $key rõ hơn vui lòng đọc thêm tại Laravel Helper Functions.

Contribute

https://github.com/thinhbuzz/laravel-setting/pulls