X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/c429cf78187e80deb63982a282a1c6889f30291a..refs/pull/3503/head:/app/Http/Controllers/SettingController.php diff --git a/app/Http/Controllers/SettingController.php b/app/Http/Controllers/SettingController.php index d9f172081..f5e48ca4c 100644 --- a/app/Http/Controllers/SettingController.php +++ b/app/Http/Controllers/SettingController.php @@ -9,28 +9,37 @@ use Illuminate\Http\Request; class SettingController extends Controller { - protected $imageRepo; + protected ImageRepo $imageRepo; + + protected array $settingCategories = ['features', 'customization', 'registration']; - /** - * SettingController constructor. - */ public function __construct(ImageRepo $imageRepo) { $this->imageRepo = $imageRepo; } /** - * Display a listing of the settings. + * Handle requests to the settings index path. */ public function index() { + return redirect('/settings/features'); + } + + /** + * Display the settings for the given category. + */ + public function category(string $category) + { + $this->ensureCategoryExists($category); $this->checkPermission('settings-manage'); $this->setPageTitle(trans('settings.settings')); // Get application version $version = trim(file_get_contents(base_path('version'))); - return view('settings.index', [ + return view('settings.' . $category, [ + 'category' => $category, 'version' => $version, 'guestUser' => User::getDefault(), ]); @@ -39,12 +48,13 @@ class SettingController extends Controller /** * Update the specified settings in storage. */ - public function update(Request $request) + public function update(Request $request, string $category) { + $this->ensureCategoryExists($category); $this->preventAccessInDemoMode(); $this->checkPermission('settings-manage'); $this->validate($request, [ - 'app_logo' => 'nullable|' . $this->getImageValidationRules(), + 'app_logo' => array_merge(['nullable'], $this->getImageValidationRules()), ]); // Cycles through posted settings and update them @@ -57,7 +67,7 @@ class SettingController extends Controller } // Update logo image if set - if ($request->hasFile('app_logo')) { + if ($category === 'customization' && $request->hasFile('app_logo')) { $logoFile = $request->file('app_logo'); $this->imageRepo->destroyByType('system'); $image = $this->imageRepo->saveNew($logoFile, 'system', 0, null, 86); @@ -65,16 +75,21 @@ class SettingController extends Controller } // Clear logo image if requested - if ($request->get('app_logo_reset', null)) { + if ($category === 'customization' && $request->get('app_logo_reset', null)) { $this->imageRepo->destroyByType('system'); setting()->remove('app-logo'); } - $section = $request->get('section', ''); - $this->logActivity(ActivityType::SETTINGS_UPDATE, $section); + $this->logActivity(ActivityType::SETTINGS_UPDATE, $category); $this->showSuccessNotification(trans('settings.settings_save_success')); - $redirectLocation = '/settings#' . $section; - return redirect(rtrim($redirectLocation, '#')); + return redirect("/settings/{$category}"); + } + + protected function ensureCategoryExists(string $category): void + { + if (!in_array($category, $this->settingCategories)) { + abort(404); + } } }