X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/80865b30a5d6a82e86d21e272ae58977d4430a64..refs/pull/2902/head:/app/Http/Controllers/SettingController.php diff --git a/app/Http/Controllers/SettingController.php b/app/Http/Controllers/SettingController.php index c43e6e399..d9f172081 100644 --- a/app/Http/Controllers/SettingController.php +++ b/app/Http/Controllers/SettingController.php @@ -2,47 +2,79 @@ namespace BookStack\Http\Controllers; +use BookStack\Actions\ActivityType; +use BookStack\Auth\User; +use BookStack\Uploads\ImageRepo; use Illuminate\Http\Request; -use BookStack\Http\Requests; -use BookStack\Http\Controllers\Controller; -use Setting; - class SettingController extends Controller { + protected $imageRepo; + + /** + * SettingController constructor. + */ + public function __construct(ImageRepo $imageRepo) + { + $this->imageRepo = $imageRepo; + } + /** * Display a listing of the settings. - * - * @return Response */ public function index() { $this->checkPermission('settings-manage'); - $this->setPageTitle('Settings'); - return view('settings/index'); - } + $this->setPageTitle(trans('settings.settings')); + // Get application version + $version = trim(file_get_contents(base_path('version'))); + + return view('settings.index', [ + 'version' => $version, + 'guestUser' => User::getDefault(), + ]); + } /** * Update the specified settings in storage. - * - * @param Request $request - * @return Response */ public function update(Request $request) { - $this->preventAccessForDemoUsers(); + $this->preventAccessInDemoMode(); $this->checkPermission('settings-manage'); + $this->validate($request, [ + 'app_logo' => 'nullable|' . $this->getImageValidationRules(), + ]); // Cycles through posted settings and update them - foreach($request->all() as $name => $value) { - if(strpos($name, 'setting-') !== 0) continue; + foreach ($request->all() as $name => $value) { $key = str_replace('setting-', '', trim($name)); - Setting::put($key, $value); + if (strpos($name, 'setting-') !== 0) { + continue; + } + setting()->put($key, $value); } - session()->flash('success', 'Settings Saved'); - return redirect('/settings'); - } + // Update logo image if set + if ($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 ($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->showSuccessNotification(trans('settings.settings_save_success')); + $redirectLocation = '/settings#' . $section; + + return redirect(rtrim($redirectLocation, '#')); + } }