mirror of
https://github.com/Bubka/2FAuth.git
synced 2025-01-12 09:18:13 +01:00
63 lines
1.6 KiB
PHP
63 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace App\Classes;
|
|
|
|
class Options
|
|
{
|
|
|
|
/**
|
|
* Compile both default and user options
|
|
*
|
|
* @return Options collection or a signle
|
|
*/
|
|
public static function get($option = null)
|
|
{
|
|
// Get a collection of user saved options
|
|
$userOptions = \Illuminate\Support\Facades\DB::table('options')->pluck('value', 'key');
|
|
|
|
// We replace patterned string that represent booleans with real booleans
|
|
$userOptions->transform(function ($item, $key) {
|
|
if( $item === '{{}}' ) {
|
|
return false;
|
|
}
|
|
else if( $item === '{{1}}' ) {
|
|
return true;
|
|
}
|
|
else {
|
|
return $item;
|
|
}
|
|
});
|
|
|
|
// Merge options from App configuration. It ensures we have a complete options collection with
|
|
// fallback values for every options
|
|
$options = collect(config('app.options'))->merge($userOptions);
|
|
|
|
if( $option ) {
|
|
|
|
return isset($options[$option]) ? $options[$option] : null;
|
|
}
|
|
|
|
return $options;
|
|
}
|
|
|
|
|
|
/**
|
|
* Set user options
|
|
*
|
|
* @param array All options to store
|
|
* @return void
|
|
*/
|
|
public static function store($userOptions)
|
|
{
|
|
foreach($userOptions as $opt => $val) {
|
|
|
|
// We replace boolean values by a patterned string in order to retrieve
|
|
// them later (as the Laravel Options package do not support var type)
|
|
// Not a beatufilly solution but, hey, it works ^_^
|
|
option([$opt => is_bool($val) ? '{{' . $val . '}}' : $val]);
|
|
}
|
|
}
|
|
|
|
|
|
}
|