* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0 */ namespace App\Http\Controllers\User; use App\Enums\UserGroup; use App\Http\Controllers\Controller; use App\Http\Requests\UpsertUserPrivacyRequest; use App\Models\Group; use App\Models\User; use App\Models\UserPrivacy; use Illuminate\Http\Request; class PrivacySettingController extends Controller { /** * Update user privacy settings. */ public function update(UpsertUserPrivacyRequest $request, User $user): \Illuminate\Http\RedirectResponse { abort_unless($request->user()->is($user), 403); // Can't use upsert here because upsert doesn't serialize the custom // array cast to a string before upserting UserPrivacy::updateOrCreate(['user_id' => $user->id], $request->validated()); cache()->forget('user-privacy:by-user-id:'.$user->id); return to_route('users.privacy_settings.edit', ['user' => $user]) ->withSuccess('Your privacy settings have been successfully saved.'); } /** * Edit user privacy settings. */ public function edit(Request $request, User $user): \Illuminate\Contracts\View\Factory|\Illuminate\View\View { abort_unless($request->user()->is($user), 403); return view('user.privacy_setting.edit', [ 'user' => $user, 'groups' => Group::query() ->where('is_modo', '=', false) ->where('is_admin', '=', false) ->where('id', '!=', UserGroup::VALIDATING->value) ->where('id', '!=', UserGroup::PRUNED->value) ->where('id', '!=', UserGroup::BANNED->value) ->where('id', '!=', UserGroup::DISABLED->value) ->latest('level') ->get(), ]); } }