X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/cd6572b61af2165133468d2562d04dffdca8fca8..refs/pull/3499/head:/app/Http/Controllers/SettingController.php diff --git a/app/Http/Controllers/SettingController.php b/app/Http/Controllers/SettingController.php index 70a12631a..f5e48ca4c 100644 --- a/app/Http/Controllers/SettingController.php +++ b/app/Http/Controllers/SettingController.php @@ -1,45 +1,95 @@ -imageRepo = $imageRepo; + } + /** - * Display a listing of the settings. - * @return Response + * 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('Settings'); + $this->setPageTitle(trans('settings.settings')); // Get application version $version = trim(file_get_contents(base_path('version'))); - return view('settings/index', ['version' => $version]); + return view('settings.' . $category, [ + 'category' => $category, + 'version' => $version, + 'guestUser' => User::getDefault(), + ]); } /** * Update the specified settings in storage. - * @param Request $request - * @return Response */ - public function update(Request $request) + public function update(Request $request, string $category) { - $this->preventAccessForDemoUsers(); + $this->ensureCategoryExists($category); + $this->preventAccessInDemoMode(); $this->checkPermission('settings-manage'); + $this->validate($request, [ + 'app_logo' => array_merge(['nullable'], $this->getImageValidationRules()), + ]); // Cycles through posted settings and update them foreach ($request->all() as $name => $value) { - if (strpos($name, 'setting-') !== 0) continue; $key = str_replace('setting-', '', trim($name)); - Setting::put($key, $value); + if (strpos($name, 'setting-') !== 0) { + continue; + } + setting()->put($key, $value); + } + + // Update logo image if set + 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); + setting()->put('app-logo', $image->url); + } + + // Clear logo image if requested + if ($category === 'customization' && $request->get('app_logo_reset', null)) { + $this->imageRepo->destroyByType('system'); + setting()->remove('app-logo'); } - session()->flash('success', trans('settings.settings_save_success')); - return redirect('/settings'); + $this->logActivity(ActivityType::SETTINGS_UPDATE, $category); + $this->showSuccessNotification(trans('settings.settings_save_success')); + + return redirect("/settings/{$category}"); } + protected function ensureCategoryExists(string $category): void + { + if (!in_array($category, $this->settingCategories)) { + abort(404); + } + } }