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(),
]);
/**
* 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, [
}
// 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);
}
// 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);
+ }
}
}