-<?php namespace BookStack\Http\Controllers;
+<?php
-use BookStack\Services\ImageService;
+namespace BookStack\Http\Controllers;
+
+use BookStack\Actions\ActivityType;
+use BookStack\Auth\User;
+use BookStack\Uploads\ImageRepo;
use Illuminate\Http\Request;
-use Illuminate\Http\Response;
-use Setting;
class SettingController extends Controller
{
+ protected ImageRepo $imageRepo;
+
+ protected array $settingCategories = ['features', 'customization', 'registration'];
+
+ public function __construct(ImageRepo $imageRepo)
+ {
+ $this->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(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) {
+ $key = str_replace('setting-', '', trim($name));
if (strpos($name, 'setting-') !== 0) {
continue;
}
- $key = str_replace('setting-', '', trim($name));
- Setting::put($key, $value);
+ setting()->put($key, $value);
}
- session()->flash('success', trans('settings.settings_save_success'));
- return redirect('/settings');
- }
+ // 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);
+ }
- /**
- * Show the page for application maintenance.
- * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
- */
- public function showMaintenance()
- {
- $this->checkPermission('settings-manage');
- $this->setPageTitle(trans('settings.maint'));
+ // Clear logo image if requested
+ if ($category === 'customization' && $request->get('app_logo_reset', null)) {
+ $this->imageRepo->destroyByType('system');
+ setting()->remove('app-logo');
+ }
- // Get application version
- $version = trim(file_get_contents(base_path('version')));
+ $this->logActivity(ActivityType::SETTINGS_UPDATE, $category);
+ $this->showSuccessNotification(trans('settings.settings_save_success'));
- return view('settings/maintenance', ['version' => $version]);
+ return redirect("/settings/{$category}");
}
- /**
- * Action to clean-up images in the system.
- * @param Request $request
- * @param ImageService $imageService
- * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector
- */
- public function cleanupImages(Request $request, ImageService $imageService)
+ protected function ensureCategoryExists(string $category): void
{
- $this->checkPermission('settings-manage');
-
- $checkRevisions = !($request->get('ignore_revisions', 'false') === 'true');
- $dryRun = !($request->has('confirm'));
-
- $imagesToDelete = $imageService->deleteUnusedImages($checkRevisions, $dryRun);
- $deleteCount = count($imagesToDelete);
- if ($deleteCount === 0) {
- session()->flash('warning', trans('settings.maint_image_cleanup_nothing_found'));
- return redirect('/settings/maintenance')->withInput();
+ if (!in_array($category, $this->settingCategories)) {
+ abort(404);
}
-
- if ($dryRun) {
- session()->flash('cleanup-images-warning', trans('settings.maint_image_cleanup_warning', ['count' => $deleteCount]));
- } else {
- session()->flash('success', trans('settings.maint_image_cleanup_success', ['count' => $deleteCount]));
- }
-
- return redirect('/settings/maintenance#image-cleanup')->withInput();
}
}