rbrecruiter/app/Http/Controllers/OptionsController.php

116 lines
4.3 KiB
PHP
Raw Normal View History

2020-08-30 22:06:01 +00:00
<?php
2020-10-10 16:30:26 +00:00
/*
* Copyright © 2020 Miguel Nogueira
*
* This file is part of Raspberry Staff Manager.
*
* Raspberry Staff Manager is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Raspberry Staff Manager is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Raspberry Staff Manager. If not, see <https://www.gnu.org/licenses/>.
*/
2020-08-30 22:06:01 +00:00
namespace App\Http\Controllers;
2020-08-31 18:53:10 +00:00
use App\Facades\Options;
2020-08-31 16:55:36 +00:00
use App\Options as Option;
2020-08-30 22:06:01 +00:00
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
2020-09-07 21:54:20 +00:00
use Illuminate\Support\Facades\Log;
2020-08-30 22:06:01 +00:00
class OptionsController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Contracts\Foundation\Application|\Illuminate\Contracts\View\Factory|\Illuminate\Http\Response|\Illuminate\View\View
*/
public function index()
{
2020-08-31 16:58:07 +00:00
return view('dashboard.administration.settings')
->with([
'options' => Options::getCategory('notifications'),
'security' => [ // We could use the method above, but we need to set these names here for greater control in the template. This would nto be feasible for many options, we'd need to use a loop and the category method.
'secPolicy' => Options::getOption('pw_security_policy'),
'graceperiod' => Options::getOption('graceperiod'),
'pwExpiry' => Options::getOption('password_expiry'),
'requiresPMC' => Options::getOption('requireGameLicense'),
'enforce2fa' => Options::getOption('force2fa')
2021-01-06 01:55:22 +00:00
],
'currentGame' => Options::getOption('currentGame')
2021-01-06 00:57:27 +00:00
]);
2020-08-30 22:06:01 +00:00
}
2020-10-10 16:30:26 +00:00
public function saveSettings(Request $request)
{
if (Auth::user()->can('admin.settings.edit')) {
Log::debug('Updating application options', [
'ip' => $request->ip(),
'ua' => $request->userAgent(),
'username' => Auth::user()->username,
]);
foreach ($request->all() as $optionName => $option) {
try {
Log::debug('Going through option '.$optionName);
if (Options::optionExists($optionName)) {
Log::debug('Option exists, updating to new values', [
'opt' => $optionName,
'new_value' => $option,
]);
Options::changeOption($optionName, $option);
}
} catch (\Exception $ex) {
Log::error('Unable to update options!', [
'msg' => $ex->getMessage(),
'trace' => $ex->getTraceAsString(),
]);
report($ex);
2020-09-07 21:54:20 +00:00
2020-10-10 16:30:26 +00:00
$errorCond = true;
$request->session()->flash('error', 'An error occurred while trying to save settings: '.$ex->getMessage());
}
}
2020-08-30 22:06:01 +00:00
2020-10-10 16:30:26 +00:00
if (! isset($errorCond)) {
$request->session()->flash('success', 'Settings saved successfully!');
}
} else {
$request->session()->flash('error', 'You do not have permission to update this resource.');
}
2020-08-30 22:06:01 +00:00
2020-10-10 16:30:26 +00:00
return redirect()->back();
}
2021-01-06 01:55:22 +00:00
public function saveGameIntegration(Request $request)
{
$supportedGames = [
'RUST',
'MINECRAFT',
'SE',
'GMOD'
];
if (!is_null($request->gamePref) && in_array($request->gamePref, $supportedGames))
{
Options::changeOption('currentGame', $request->gamePref);
$request->session()->flash('success', 'Updated current game.');
return redirect()->back();
}
$request->session()->flash('error', 'Unsupported game ' . $request->gamePref . '.');
return redirect()->back();
}
2020-08-30 22:06:01 +00:00
}