middleware(['auth', 'verified', '2fa']); } /** * Show the application dashboard. * * @param int $page * @return \Illuminate\Contracts\Support\Renderable */ public function index($page = 1) { $pages = User::count(); $pages = (int) ceil($pages/25); if($pages < 1 && $page == 1) $page = 1; if($page < 1 || ($pages > 0 && $page > $pages)) return redirect()->route('panel.ums', [ 'page' => ($pages > 0 ? $pages : 1) ]); $data = User::select('id', 'uuid', 'last_active', 'is_admin', 'is_root')->get(); return view('panel.ums.index')->with([ 'users' => $data, 'page' => $page, 'pages' => $pages ]); } public function info($id) { $user = User::findOrFail($id); return view('panel.ums.info')->with([ 'user' => $user ]); } public function edit($id) { $user = Auth::user(); if(!$user->is_root && !$user->is_admin) return Redirect::route('panel.ums'); return view('panel.ums.edit')->with([ 'user' => $user ]); } public function update(Request $request) { if(!$request->has('id')) return Redirect::back(); $user = User::findOrFail($request->get('id')); if($request->get('email') !== $user->email) { $validator = Validator::make($request->all(), [ 'email' => ['required', 'email', 'unique:users,email', 'max:255'] ]); if(!$validator->passes()) return Redirect::back()->withErrors($validator); $change = ChangeEmail::create([ 'user_id' => $user->id, 'email' => $request->get('email'), 'token' => Str::random(12) ]); Mail::to($user)->send(new SendMailChange($change)); } if(Auth::user()->is_root) { $validator = Validator::make($request->all(), [ 'is_admin' => ['required', 'boolean'], 'is_root' => ['required', 'boolean'] ]); if(!$validator->passes()) return Redirect::back()->withErrors($validator); $user->is_admin = $request->get('is_admin'); $user->is_root = $request->get('is_root'); if($user->save()) { session()->flash('success', 'Successfully edited user: '.$user->uuid); } else { session()->flash('error', 'Unable to edit user: '.$user->uuid); } } return Redirect::route('panel.ums'); } public function delete($id) { $auth = Auth::user(); if(!$auth->is_admin && !$auth->is_root) return Redirect::route('panel.home'); $user = User::findOrFail($id); if($user->delete()) { session()->flash('success', 'Successfully deleted user: '.$user->firstname); } else { session()->flash('error', 'Unable to delete user: '.$user->firstname); } return Redirect::back(); } }