
Shift automatically applies the Laravel coding style - which uses the PSR-12 coding style as a base with some minor additions. You may customize the code style applied by configuring [Pint](https://laravel.com/docs/pint), [PHP CS Fixer](https://github.com/FriendsOfPHP/PHP-CS-Fixer), or [PHP CodeSniffer](https://github.com/squizlabs/PHP_CodeSniffer) for your project root. For more information on customizing the code style applied by Shift, [watch this short video](https://laravelshift.com/videos/shift-code-style).
51 lines
1 KiB
PHP
51 lines
1 KiB
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Support\Facades\Cache;
|
|
|
|
class Settings extends Model
|
|
{
|
|
use HasFactory;
|
|
|
|
protected $table = 'settings';
|
|
|
|
public const CACHE_TAG = 'setting';
|
|
|
|
public $primaryKey = 'key';
|
|
|
|
public $incrementing = false;
|
|
|
|
protected $keyType = 'string';
|
|
|
|
protected $fillable = [
|
|
'key',
|
|
'value',
|
|
'type',
|
|
];
|
|
|
|
public static function boot()
|
|
{
|
|
parent::boot();
|
|
|
|
static::updated(function (Settings $settings) {
|
|
Cache::forget(self::CACHE_TAG.':'.$settings->key);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* @param string $key
|
|
* @param $default
|
|
* @return mixed
|
|
*/
|
|
public static function getValueByKey(string $key, $default = null)
|
|
{
|
|
return Cache::rememberForever(self::CACHE_TAG.':'.$key, function () use ($default, $key) {
|
|
$settings = self::find($key);
|
|
|
|
return $settings ? $settings->value : $default;
|
|
});
|
|
}
|
|
}
|