mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-25 12:41:16 -08:00
Added: Caching of settings (#6378)
* Fixed missing oauth tables during setup. * Cache settings Cache the setting to reduce unnecessary database calls
This commit is contained in:
parent
0730685c29
commit
88b1da4260
|
@ -41,7 +41,7 @@ class DisableLDAP extends Command
|
||||||
|
|
||||||
if ($this->confirm("\n****************************************************\nThis will disable LDAP support. You will not be able \nto login with an account that does not exist \nlocally in the Snipe-IT local database. \n****************************************************\n\nDo you wish to continue? [y|N]")) {
|
if ($this->confirm("\n****************************************************\nThis will disable LDAP support. You will not be able \nto login with an account that does not exist \nlocally in the Snipe-IT local database. \n****************************************************\n\nDo you wish to continue? [y|N]")) {
|
||||||
|
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
$setting->ldap_enabled = 0;
|
$setting->ldap_enabled = 0;
|
||||||
if ($setting->save()) {
|
if ($setting->save()) {
|
||||||
$this->info('LDAP has been set to disabled.');
|
$this->info('LDAP has been set to disabled.');
|
||||||
|
|
|
@ -52,7 +52,7 @@ class SendExpirationAlerts extends Command
|
||||||
});
|
});
|
||||||
|
|
||||||
// Expiring Assets
|
// Expiring Assets
|
||||||
$assets = Asset::getExpiringWarrantee(Setting::getSettings()->alert_interval);
|
$assets = Asset::getExpiringWarrantee($threshold);
|
||||||
if ($assets->count() > 0) {
|
if ($assets->count() > 0) {
|
||||||
$this->info(trans_choice('mail.assets_warrantee_alert', $assets->count(), ['count' => $assets->count(), 'threshold' => $threshold]));
|
$this->info(trans_choice('mail.assets_warrantee_alert', $assets->count(), ['count' => $assets->count(), 'threshold' => $threshold]));
|
||||||
Notification::send($recipients, new ExpiringAssetsNotification($assets, $threshold));
|
Notification::send($recipients, new ExpiringAssetsNotification($assets, $threshold));
|
||||||
|
|
20
app/Events/SettingSaved.php
Normal file
20
app/Events/SettingSaved.php
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Events;
|
||||||
|
|
||||||
|
use App\Models\Setting;
|
||||||
|
|
||||||
|
class SettingSaved
|
||||||
|
{
|
||||||
|
public $settings;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new event instance.
|
||||||
|
*
|
||||||
|
* @param \App\Models\Setting $settings
|
||||||
|
*/
|
||||||
|
public function __construct(Setting $settings)
|
||||||
|
{
|
||||||
|
$this->settings = $settings;
|
||||||
|
}
|
||||||
|
}
|
|
@ -173,7 +173,7 @@ class ReportsController extends Controller
|
||||||
if ($asset->location) {
|
if ($asset->location) {
|
||||||
$currency = e($asset->location->currency);
|
$currency = e($asset->location->currency);
|
||||||
} else {
|
} else {
|
||||||
$currency = e(Setting::first()->default_currency);
|
$currency = e(Setting::getSettings()->default_currency);
|
||||||
}
|
}
|
||||||
|
|
||||||
$row[] = $asset->purchase_date;
|
$row[] = $asset->purchase_date;
|
||||||
|
|
|
@ -267,7 +267,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$settings = Setting::all();
|
$settings = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings/index', compact('settings'));
|
return view('settings/index', compact('settings'));
|
||||||
}
|
}
|
||||||
|
@ -283,7 +283,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getEdit()
|
public function getEdit()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings/general', compact('setting'));
|
return view('settings/general', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -299,7 +299,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getSettings()
|
public function getSettings()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings/general', compact('setting'));
|
return view('settings/general', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -315,7 +315,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postSettings(Request $request)
|
public function postSettings(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -369,7 +369,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getBranding()
|
public function getBranding()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.branding', compact('setting'));
|
return view('settings.branding', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -385,7 +385,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postBranding(ImageUploadRequest $request)
|
public function postBranding(ImageUploadRequest $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -452,7 +452,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getSecurity()
|
public function getSecurity()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.security', compact('setting'));
|
return view('settings.security', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -468,7 +468,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postSecurity(Request $request)
|
public function postSecurity(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -512,7 +512,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getLocalization()
|
public function getLocalization()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.localization', compact('setting'));
|
return view('settings.localization', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -528,7 +528,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postLocalization(Request $request)
|
public function postLocalization(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -558,7 +558,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getAlerts()
|
public function getAlerts()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.alerts', compact('setting'));
|
return view('settings.alerts', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -574,7 +574,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postAlerts(Request $request)
|
public function postAlerts(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -611,7 +611,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getSlack()
|
public function getSlack()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.slack', compact('setting'));
|
return view('settings.slack', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -627,7 +627,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postSlack(Request $request)
|
public function postSlack(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -654,7 +654,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getAssetTags()
|
public function getAssetTags()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.asset_tags', compact('setting'));
|
return view('settings.asset_tags', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -670,7 +670,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postAssetTags(Request $request)
|
public function postAssetTags(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -698,7 +698,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getBarcodes()
|
public function getBarcodes()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
$is_gd_installed = extension_loaded('gd');
|
$is_gd_installed = extension_loaded('gd');
|
||||||
|
|
||||||
return view('settings.barcodes', compact('setting'))->with('is_gd_installed', $is_gd_installed);
|
return view('settings.barcodes', compact('setting'))->with('is_gd_installed', $is_gd_installed);
|
||||||
|
@ -715,7 +715,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postBarcodes(Request $request)
|
public function postBarcodes(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -763,7 +763,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getLabels()
|
public function getLabels()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.labels', compact('setting'));
|
return view('settings.labels', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -779,7 +779,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postLabels(Request $request)
|
public function postLabels(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
$setting->labels_per_page = $request->input('labels_per_page');
|
$setting->labels_per_page = $request->input('labels_per_page');
|
||||||
|
@ -845,7 +845,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function getLdapSettings()
|
public function getLdapSettings()
|
||||||
{
|
{
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
|
|
||||||
return view('settings.ldap', compact('setting'));
|
return view('settings.ldap', compact('setting'));
|
||||||
}
|
}
|
||||||
|
@ -861,7 +861,7 @@ class SettingsController extends Controller
|
||||||
*/
|
*/
|
||||||
public function postLdapSettings(Request $request)
|
public function postLdapSettings(Request $request)
|
||||||
{
|
{
|
||||||
if (is_null($setting = Setting::first())) {
|
if (is_null($setting = Setting::getSettings())) {
|
||||||
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
return redirect()->to('admin')->with('error', trans('admin/settings/message.update.error'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,10 @@ class CheckForSetup
|
||||||
public function handle($request, Closure $next, $guard = null)
|
public function handle($request, Closure $next, $guard = null)
|
||||||
{
|
{
|
||||||
|
|
||||||
// This is dumb
|
/**
|
||||||
|
* This is dumb
|
||||||
|
* @todo Check on removing this, not sure if it's still needed
|
||||||
|
*/
|
||||||
if ($request->is('_debugbar*')) {
|
if ($request->is('_debugbar*')) {
|
||||||
return $next($request);
|
return $next($request);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,52 +1,55 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace App\Http\Middleware;
|
namespace App\Http\Middleware;
|
||||||
|
|
||||||
use App\Models\Setting;
|
|
||||||
use Auth;
|
use Auth;
|
||||||
use Closure;
|
use Closure;
|
||||||
use Illuminate\Support\Facades\Schema;
|
use App\Models\Setting;
|
||||||
use Log;
|
|
||||||
|
|
||||||
class CheckForTwoFactor
|
class CheckForTwoFactor
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Routes to ignore for Two Factor Auth
|
||||||
|
*/
|
||||||
|
const IGNORE_ROUTES = ['two-factor', 'two-factor-enroll', 'setup', 'logout'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle an incoming request.
|
* Handle an incoming request.
|
||||||
*
|
*
|
||||||
* @param \Illuminate\Http\Request $request
|
* @param \Illuminate\Http\Request $request
|
||||||
* @param \Closure $next
|
* @param \Closure $next
|
||||||
|
*
|
||||||
* @return mixed
|
* @return mixed
|
||||||
*/
|
*/
|
||||||
public function handle($request, Closure $next)
|
public function handle($request, Closure $next)
|
||||||
{
|
{
|
||||||
|
|
||||||
// Skip the logic if the user is on the two factor pages or the setup pages
|
// Skip the logic if the user is on the two factor pages or the setup pages
|
||||||
if (($request->route()->getName()=='two-factor') || ($request->route()->getName()=='two-factor-enroll') || ($request->route()->getPrefix()=='setup') || ($request->route()->getName()=='logout')) {
|
if (in_array($request->route()->getName(), self::IGNORE_ROUTES)) {
|
||||||
return $next($request);
|
return $next($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Two-factor is enabled (either optional or required)
|
// Two-factor is enabled (either optional or required)
|
||||||
if (Setting::getSettings()) {
|
if ($settings = Setting::getSettings()) {
|
||||||
if (Auth::check() && (Setting::getSettings()->two_factor_enabled!='')) {
|
if (Auth::check() && ($settings->two_factor_enabled != '')) {
|
||||||
|
|
||||||
// This user is already 2fa-authed
|
// This user is already 2fa-authed
|
||||||
if ($request->session()->get('2fa_authed')) {
|
if ($request->session()->get('2fa_authed')) {
|
||||||
return $next($request);
|
return $next($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Two-factor is optional and the user has NOT opted in, let them through
|
// Two-factor is optional and the user has NOT opted in, let them through
|
||||||
if ((Setting::getSettings()->two_factor_enabled=='1') && (Auth::user()->two_factor_optin!='1')) {
|
if (($settings->two_factor_enabled == '1') && (Auth::user()->two_factor_optin != '1')) {
|
||||||
return $next($request);
|
return $next($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise make sure they're enrolled and show them the 2FA code screen
|
// Otherwise make sure they're enrolled and show them the 2FA code screen
|
||||||
if ((Auth::user()->two_factor_secret!='') && (Auth::user()->two_factor_enrolled=='1')) {
|
if ((Auth::user()->two_factor_secret != '') && (Auth::user()->two_factor_enrolled == '1')) {
|
||||||
return redirect()->route('two-factor')->with('info', 'Please enter your two-factor authentication code.');
|
return redirect()->route('two-factor')->with('info', 'Please enter your two-factor authentication code.');
|
||||||
}
|
}
|
||||||
|
|
||||||
return redirect()->route('two-factor-enroll')->with('success', 'Please enroll a device in two-factor authentication.');
|
return redirect()->route('two-factor-enroll')->with('success', 'Please enroll a device in two-factor authentication.');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return $next($request);
|
|
||||||
|
|
||||||
|
return $next($request);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,35 +4,31 @@ namespace App\Http\Middleware;
|
||||||
|
|
||||||
use Closure;
|
use Closure;
|
||||||
use Config;
|
use Config;
|
||||||
use Route;
|
|
||||||
use Schema;
|
|
||||||
use App\Models\Setting;
|
use App\Models\Setting;
|
||||||
|
|
||||||
class CheckLocale
|
class CheckLocale
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Handle the locale for the user, default to settings otherwise
|
* Handle the locale for the user, default to settings otherwise.
|
||||||
*
|
*
|
||||||
* @param \Illuminate\Http\Request $request
|
* @param \Illuminate\Http\Request $request
|
||||||
* @param \Closure $next
|
* @param \Closure $next
|
||||||
* @param string|null $guard
|
* @param string|null $guard
|
||||||
* @return mixed
|
*
|
||||||
*/
|
* @return mixed
|
||||||
|
*/
|
||||||
public function handle($request, Closure $next, $guard = null)
|
public function handle($request, Closure $next, $guard = null)
|
||||||
{
|
{
|
||||||
|
if ($settings = Setting::getSettings()) {
|
||||||
|
|
||||||
if (Setting::getSettings()) {
|
|
||||||
// User's preference
|
// User's preference
|
||||||
if (($request->user()) && ($request->user()->locale)) {
|
if (($request->user()) && ($request->user()->locale)) {
|
||||||
\App::setLocale($request->user()->locale);
|
\App::setLocale($request->user()->locale);
|
||||||
|
|
||||||
// App setting preference
|
// App setting preference
|
||||||
} elseif ((Setting::getSettings()) && (Setting::getSettings()->locale!='')) {
|
} elseif ($settings->locale != '') {
|
||||||
\App::setLocale(Setting::getSettings()->locale);
|
\App::setLocale($settings->locale);
|
||||||
|
|
||||||
// Default app setting
|
// Default app setting
|
||||||
} else {
|
} else {
|
||||||
\App::setLocale(config('app.locale'));
|
\App::setLocale(config('app.locale'));
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,24 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace App\Http\Traits;
|
namespace App\Http\Traits;
|
||||||
|
|
||||||
|
use App\Models\Setting;
|
||||||
|
|
||||||
trait UniqueSerialTrait
|
trait UniqueSerialTrait
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Prepare a unique_ids rule, adding a model identifier if required.
|
* Prepare a unique_ids rule, adding a model identifier if required.
|
||||||
*
|
*
|
||||||
* @param array $parameters
|
* @param array $parameters
|
||||||
* @param string $field
|
* @param string $field
|
||||||
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
protected function prepareUniqueSerialRule($parameters, $field)
|
protected function prepareUniqueSerialRule($parameters, $field)
|
||||||
{
|
{
|
||||||
if ($settings = \App\Models\Setting::first()) {
|
if ($settings = Setting::getSettings()) {
|
||||||
if ($settings->unique_serial=='1') {
|
if ($settings->unique_serial == '1') {
|
||||||
return 'unique_undeleted:'.$this->table.','. $this->getKey();
|
return 'unique_undeleted:'.$this->table.','.$this->getKey();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,7 +50,7 @@ class Depreciable extends SnipeModel
|
||||||
return $this->purchase_cost;
|
return $this->purchase_cost;
|
||||||
}
|
}
|
||||||
$depreciation = 0;
|
$depreciation = 0;
|
||||||
$setting = Setting::first();
|
$setting = Setting::getSettings();
|
||||||
switch($setting->depreciation_method) {
|
switch($setting->depreciation_method) {
|
||||||
case 'half_1':
|
case 'half_1':
|
||||||
$depreciation = $this->getHalfYearDepreciatedValue(true);
|
$depreciation = $this->getHalfYearDepreciatedValue(true);
|
||||||
|
|
|
@ -1,201 +1,297 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace App\Models;
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Parsedown;
|
||||||
|
use App\Events\SettingSaved;
|
||||||
|
use Illuminate\Support\Facades\App;
|
||||||
|
use Illuminate\Support\Facades\Cache;
|
||||||
|
use Watson\Validating\ValidatingTrait;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
use Illuminate\Notifications\Notifiable;
|
use Illuminate\Notifications\Notifiable;
|
||||||
use Watson\Validating\ValidatingTrait;
|
|
||||||
use Schema;
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Settings model.
|
||||||
|
*/
|
||||||
class Setting extends Model
|
class Setting extends Model
|
||||||
{
|
{
|
||||||
use Notifiable;
|
use Notifiable, ValidatingTrait;
|
||||||
protected $injectUniqueIdentifier = true;
|
|
||||||
use ValidatingTrait;
|
|
||||||
|
|
||||||
protected $rules = [
|
/**
|
||||||
'brand' => 'required|min:1|numeric',
|
* The app settings cache key name.
|
||||||
'qr_text' => 'max:31|nullable',
|
*
|
||||||
'logo_img' => 'mimes:jpeg,bmp,png,gif',
|
* @var string
|
||||||
'alert_email' => 'email_array|nullable',
|
*/
|
||||||
'admin_cc_email' => 'email|nullable',
|
const APP_SETTINGS_KEY = 'snipeit_app_settings';
|
||||||
'default_currency' => 'required',
|
|
||||||
'locale' => 'required',
|
/**
|
||||||
'slack_endpoint' => 'url|required_with:slack_channel|nullable',
|
* The setup check cache key name.
|
||||||
'slack_channel' => 'regex:/(?<!\w)#\w+/|required_with:slack_endpoint|nullable',
|
*
|
||||||
'slack_botname' => 'string|nullable',
|
* @var string
|
||||||
'labels_per_page' => 'numeric',
|
*/
|
||||||
'labels_width' => 'numeric',
|
const SETUP_CHECK_KEY = 'snipeit_setup_check';
|
||||||
'labels_height' => 'numeric',
|
|
||||||
'labels_pmargin_left' => 'numeric|nullable',
|
/**
|
||||||
'labels_pmargin_right' => 'numeric|nullable',
|
* Whether the model should inject it's identifier to the unique
|
||||||
'labels_pmargin_top' => 'numeric|nullable',
|
* validation rules before attempting validation. If this property
|
||||||
'labels_pmargin_bottom' => 'numeric|nullable',
|
* is not set in the model it will default to true.
|
||||||
'labels_display_bgutter' => 'numeric|nullable',
|
*
|
||||||
'labels_display_sgutter' => 'numeric|nullable',
|
* @var bool
|
||||||
'labels_fontsize' => 'numeric|min:5',
|
*/
|
||||||
'labels_pagewidth' => 'numeric|nullable',
|
protected $injectUniqueIdentifier = true;
|
||||||
'labels_pageheight' => 'numeric|nullable',
|
|
||||||
'login_remote_user_enabled' => 'numeric|nullable',
|
/**
|
||||||
'login_common_disabled' => 'numeric|nullable',
|
* The event map for the model.
|
||||||
'login_remote_user_custom_logout_url' => 'string|nullable',
|
*
|
||||||
'thumbnail_max_h' => 'numeric|max:500|min:25',
|
* @var array
|
||||||
'pwd_secure_min' => 'numeric|required|min:5',
|
*/
|
||||||
'audit_warning_days' => 'numeric|nullable',
|
protected $dispatchesEvents = [
|
||||||
'audit_interval' => 'numeric|nullable',
|
'saved' => SettingSaved::class,
|
||||||
'custom_forgot_pass_url' => 'url|nullable',
|
|
||||||
'privacy_policy_link' => 'nullable|url'
|
|
||||||
];
|
];
|
||||||
|
|
||||||
protected $fillable = ['site_name','email_domain','email_format','username_format'];
|
/**
|
||||||
|
* Model rules.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $rules = [
|
||||||
|
'brand' => 'required|min:1|numeric',
|
||||||
|
'qr_text' => 'max:31|nullable',
|
||||||
|
'logo_img' => 'mimes:jpeg,bmp,png,gif',
|
||||||
|
'alert_email' => 'email_array|nullable',
|
||||||
|
'admin_cc_email' => 'email|nullable',
|
||||||
|
'default_currency' => 'required',
|
||||||
|
'locale' => 'required',
|
||||||
|
'slack_endpoint' => 'url|required_with:slack_channel|nullable',
|
||||||
|
'slack_channel' => 'regex:/(?<!\w)#\w+/|required_with:slack_endpoint|nullable',
|
||||||
|
'slack_botname' => 'string|nullable',
|
||||||
|
'labels_per_page' => 'numeric',
|
||||||
|
'labels_width' => 'numeric',
|
||||||
|
'labels_height' => 'numeric',
|
||||||
|
'labels_pmargin_left' => 'numeric|nullable',
|
||||||
|
'labels_pmargin_right' => 'numeric|nullable',
|
||||||
|
'labels_pmargin_top' => 'numeric|nullable',
|
||||||
|
'labels_pmargin_bottom' => 'numeric|nullable',
|
||||||
|
'labels_display_bgutter' => 'numeric|nullable',
|
||||||
|
'labels_display_sgutter' => 'numeric|nullable',
|
||||||
|
'labels_fontsize' => 'numeric|min:5',
|
||||||
|
'labels_pagewidth' => 'numeric|nullable',
|
||||||
|
'labels_pageheight' => 'numeric|nullable',
|
||||||
|
'login_remote_user_enabled' => 'numeric|nullable',
|
||||||
|
'login_common_disabled' => 'numeric|nullable',
|
||||||
|
'login_remote_user_custom_logout_url' => 'string|nullable',
|
||||||
|
'thumbnail_max_h' => 'numeric|max:500|min:25',
|
||||||
|
'pwd_secure_min' => 'numeric|required|min:5',
|
||||||
|
'audit_warning_days' => 'numeric|nullable',
|
||||||
|
'audit_interval' => 'numeric|nullable',
|
||||||
|
'custom_forgot_pass_url' => 'url|nullable',
|
||||||
|
'privacy_policy_link' => 'nullable|url',
|
||||||
|
];
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'site_name',
|
||||||
|
'email_domain',
|
||||||
|
'email_format',
|
||||||
|
'username_format',
|
||||||
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the app settings.
|
||||||
|
* Cache is expired on Setting model saved in EventServiceProvider.
|
||||||
|
*
|
||||||
|
* @author Wes Hulette <jwhulette@gmail.com>
|
||||||
|
*
|
||||||
|
* @since 5.0.0
|
||||||
|
*
|
||||||
|
* @return \App\Models\Setting
|
||||||
|
*/
|
||||||
public static function getSettings()
|
public static function getSettings()
|
||||||
{
|
{
|
||||||
static $static_cache = null;
|
return Cache::rememberForever(self::APP_SETTINGS_KEY, function () {
|
||||||
|
return self::first();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
if (!$static_cache) {
|
/**
|
||||||
if (Schema::hasTable('settings')) {
|
* Check to see if setup process is complete.
|
||||||
$static_cache = Setting::first();
|
* Cache is expired on Setting model saved in EventServiceProvider.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public static function setupCompleted(): bool
|
||||||
|
{
|
||||||
|
return Cache::rememberForever(self::SETUP_CHECK_KEY, function () {
|
||||||
|
try {
|
||||||
|
$usercount = User::withTrashed()->count();
|
||||||
|
$settingsCount = self::count();
|
||||||
|
|
||||||
|
return $usercount > 0 && $settingsCount > 0;
|
||||||
|
} catch (\Throwable $th) {
|
||||||
|
// Catche the error if the tables dont exit
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return $static_cache;
|
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function setupCompleted()
|
/**
|
||||||
|
* Get the current Laravel version.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function lar_ver(): string
|
||||||
{
|
{
|
||||||
|
$app = App::getFacadeApplication();
|
||||||
|
|
||||||
$users_table_exists = Schema::hasTable('users');
|
|
||||||
$settings_table_exists = Schema::hasTable('settings');
|
|
||||||
|
|
||||||
if ($users_table_exists && $settings_table_exists) {
|
|
||||||
$usercount = User::withTrashed()->count();
|
|
||||||
$settingsCount = Setting::count();
|
|
||||||
return ($usercount > 0 && $settingsCount > 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public function lar_ver()
|
|
||||||
{
|
|
||||||
$app = \App::getFacadeApplication();
|
|
||||||
return $app::VERSION;
|
return $app::VERSION;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getDefaultEula()
|
/**
|
||||||
|
* Get the default EULA text.
|
||||||
|
*
|
||||||
|
* @return string|null
|
||||||
|
*/
|
||||||
|
public static function getDefaultEula(): ?string
|
||||||
{
|
{
|
||||||
$Parsedown = new \Parsedown();
|
if (self::getSettings()->default_eula_text) {
|
||||||
if (Setting::getSettings()->default_eula_text) {
|
$parsedown = new Parsedown();
|
||||||
return $Parsedown->text(e(Setting::getSettings()->default_eula_text));
|
|
||||||
|
return $parsedown->text(e(self::getSettings()->default_eula_text));
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function modellistCheckedValue ($element) {
|
/**
|
||||||
|
* Check wether to show in model dropdowns.
|
||||||
|
*
|
||||||
|
* @param string $element
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function modellistCheckedValue($element): bool
|
||||||
|
{
|
||||||
|
$settings = self::getSettings();
|
||||||
// If the value is blank for some reason
|
// If the value is blank for some reason
|
||||||
if ($this->modellist_displays=='') {
|
if ($settings->modellist_displays == '') {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$values = explode(',', $this->modellist_displays);
|
|
||||||
|
$values = explode(',', $settings->modellist_displays);
|
||||||
|
|
||||||
foreach ($values as $value) {
|
foreach ($values as $value) {
|
||||||
if ($value == $element) {
|
if ($value == $element) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Escapes the custom CSS, and then un-escapes the greater-than symbol
|
* Escapes the custom CSS, and then un-escapes the greater-than symbol
|
||||||
* so it can work with direct descendant characters for bootstrap
|
* so it can work with direct descendant characters for bootstrap
|
||||||
* menu overrides like:
|
* menu overrides like:.
|
||||||
*
|
*
|
||||||
* .skin-blue .sidebar-menu>li.active>a, .skin-blue .sidebar-menu>li:hover>a
|
* .skin-blue .sidebar-menu>li.active>a, .skin-blue .sidebar-menu>li:hover>a
|
||||||
*
|
*
|
||||||
* Important: Do not remove the e() escaping here, as we output raw in the blade.
|
* Important: Do not remove the e() escaping here, as we output raw in the blade.
|
||||||
*
|
*
|
||||||
* @return string escaped CSS
|
* @return string escaped CSS
|
||||||
|
*
|
||||||
* @author A. Gianotto <snipe@snipe.net>
|
* @author A. Gianotto <snipe@snipe.net>
|
||||||
*/
|
*/
|
||||||
public function show_custom_css()
|
public function show_custom_css(): string
|
||||||
{
|
{
|
||||||
$custom_css = Setting::getSettings()->custom_css;
|
$custom_css = self::getSettings()->custom_css;
|
||||||
$custom_css = e($custom_css);
|
$custom_css = e($custom_css);
|
||||||
// Needed for modifying the bootstrap nav :(
|
// Needed for modifying the bootstrap nav :(
|
||||||
$custom_css = str_ireplace('script', 'SCRIPTS-NOT-ALLOWED-HERE', $custom_css);
|
$custom_css = str_ireplace('script', 'SCRIPTS-NOT-ALLOWED-HERE', $custom_css);
|
||||||
$custom_css = str_replace('>', '>', $custom_css);
|
$custom_css = str_replace('>', '>', $custom_css);
|
||||||
|
|
||||||
return $custom_css;
|
return $custom_css;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts bytes into human readable file size.
|
* Converts bytes into human readable file size.
|
||||||
*
|
*
|
||||||
* @param string $bytes
|
* @param string $bytes
|
||||||
* @return string human readable file size (2,87 Мб)
|
*
|
||||||
* @author Mogilev Arseny
|
* @return string human readable file size (2,87 Мб)
|
||||||
*/
|
*
|
||||||
public static function fileSizeConvert($bytes)
|
* @author Mogilev Arseny
|
||||||
|
*/
|
||||||
|
public static function fileSizeConvert($bytes): string
|
||||||
{
|
{
|
||||||
$bytes = floatval($bytes);
|
$bytes = floatval($bytes);
|
||||||
$arBytes = array(
|
$arBytes = [
|
||||||
0 => array(
|
0 => [
|
||||||
"UNIT" => "TB",
|
'UNIT' => 'TB',
|
||||||
"VALUE" => pow(1024, 4)
|
'VALUE' => pow(1024, 4),
|
||||||
),
|
],
|
||||||
1 => array(
|
1 => [
|
||||||
"UNIT" => "GB",
|
'UNIT' => 'GB',
|
||||||
"VALUE" => pow(1024, 3)
|
'VALUE' => pow(1024, 3),
|
||||||
),
|
],
|
||||||
2 => array(
|
2 => [
|
||||||
"UNIT" => "MB",
|
'UNIT' => 'MB',
|
||||||
"VALUE" => pow(1024, 2)
|
'VALUE' => pow(1024, 2),
|
||||||
),
|
],
|
||||||
3 => array(
|
3 => [
|
||||||
"UNIT" => "KB",
|
'UNIT' => 'KB',
|
||||||
"VALUE" => 1024
|
'VALUE' => 1024,
|
||||||
),
|
],
|
||||||
4 => array(
|
4 => [
|
||||||
"UNIT" => "B",
|
'UNIT' => 'B',
|
||||||
"VALUE" => 1
|
'VALUE' => 1,
|
||||||
),
|
],
|
||||||
);
|
];
|
||||||
|
|
||||||
foreach ($arBytes as $arItem) {
|
foreach ($arBytes as $arItem) {
|
||||||
if ($bytes >= $arItem["VALUE"]) {
|
if ($bytes >= $arItem['VALUE']) {
|
||||||
$result = $bytes / $arItem["VALUE"];
|
$result = $bytes / $arItem['VALUE'];
|
||||||
$result = round($result, 2) .$arItem["UNIT"];
|
$result = round($result, 2).$arItem['UNIT'];
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return $result;
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The url for slack notifications.
|
* The url for slack notifications.
|
||||||
* Used by Notifiable trait.
|
* Used by Notifiable trait.
|
||||||
* @return mixed
|
*
|
||||||
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function routeNotificationForSlack()
|
public function routeNotificationForSlack(): string
|
||||||
{
|
{
|
||||||
// At this point the endpoint is the same for everything.
|
// At this point the endpoint is the same for everything.
|
||||||
// In the future this may want to be adapted for individual notifications.
|
// In the future this may want to be adapted for individual notifications.
|
||||||
return $this->slack_endpoint;
|
return self::getSettings()->slack_endpoint;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function routeNotificationForMail()
|
/**
|
||||||
|
* Get the mail reply to address from configuration.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function routeNotificationForMail(): string
|
||||||
{
|
{
|
||||||
// At this point the endpoint is the same for everything.
|
// At this point the endpoint is the same for everything.
|
||||||
// In the future this may want to be adapted for individual notifications.
|
// In the future this may want to be adapted for individual notifications.
|
||||||
return config('mail.reply_to.address');
|
return config('mail.reply_to.address');
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function passwordComplexityRulesSaving($action = 'update')
|
/**
|
||||||
|
* Get the password complexity rule.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function passwordComplexityRulesSaving($action = 'update'): string
|
||||||
{
|
{
|
||||||
$security_rules = '';
|
$security_rules = '';
|
||||||
$settings = Setting::getSettings();
|
$settings = self::getSettings();
|
||||||
|
|
||||||
// Check if they have uncommon password enforcement selected in settings
|
// Check if they have uncommon password enforcement selected in settings
|
||||||
if ($settings->pwd_secure_uncommon == 1) {
|
if ($settings->pwd_secure_uncommon == 1) {
|
||||||
|
@ -203,8 +299,8 @@ class Setting extends Model
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for any secure password complexity rules that may have been selected
|
// Check for any secure password complexity rules that may have been selected
|
||||||
if ($settings->pwd_secure_complexity!='') {
|
if ($settings->pwd_secure_complexity != '') {
|
||||||
$security_rules .= '|'.$settings->pwd_secure_complexity;
|
$security_rules .= '|'.$settings->pwd_secure_complexity;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action == 'update') {
|
if ($action == 'update') {
|
||||||
|
@ -212,9 +308,5 @@ class Setting extends Model
|
||||||
}
|
}
|
||||||
|
|
||||||
return 'required|min:'.$settings->pwd_secure_min.$security_rules;
|
return 'required|min:'.$settings->pwd_secure_min.$security_rules;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,7 +57,7 @@ class AssetObserver
|
||||||
*/
|
*/
|
||||||
public function created(Asset $asset)
|
public function created(Asset $asset)
|
||||||
{
|
{
|
||||||
if ($settings = Setting::first()) {
|
if ($settings = Setting::getSettings()) {
|
||||||
$settings->increment('next_auto_tag_base');
|
$settings->increment('next_auto_tag_base');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,9 +2,12 @@
|
||||||
|
|
||||||
namespace App\Providers;
|
namespace App\Providers;
|
||||||
|
|
||||||
|
use App\Models\Setting;
|
||||||
|
use App\Events\SettingSaved;
|
||||||
|
use App\Listeners\LogListener;
|
||||||
|
use Illuminate\Support\Facades\Cache;
|
||||||
use Illuminate\Support\Facades\Event;
|
use Illuminate\Support\Facades\Event;
|
||||||
use App\Listeners\CheckoutableListener;
|
use App\Listeners\CheckoutableListener;
|
||||||
use App\Listeners\LogListener;
|
|
||||||
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;
|
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;
|
||||||
|
|
||||||
class EventServiceProvider extends ServiceProvider
|
class EventServiceProvider extends ServiceProvider
|
||||||
|
@ -44,6 +47,12 @@ class EventServiceProvider extends ServiceProvider
|
||||||
{
|
{
|
||||||
parent::boot();
|
parent::boot();
|
||||||
|
|
||||||
//
|
/**
|
||||||
|
* Clear the LDAP settings cache when the settings model is saved
|
||||||
|
*/
|
||||||
|
Event::listen(SettingSaved::class, function () {
|
||||||
|
Cache::forget(Setting::APP_SETTINGS_KEY);
|
||||||
|
Cache::forget(Setting::SETUP_CHECK_KEY);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue