] * @since [v1.0] * @return \Illuminate\Contracts\View\View */ public function getIndex() { $user = Auth::user(); $location_list = Helper::locationsList(); return view('account/profile', compact('user'))->with('location_list', $location_list); } /** * Validates and stores the user's update data. * * @author [A. Gianotto] [] * @since [v1.0] * @return \Illuminate\Http\RedirectResponse */ public function postIndex() { $user = Auth::user(); $user->first_name = Input::get('first_name'); $user->last_name = Input::get('last_name'); $user->website = Input::get('website'); $user->location_id = Input::get('location_id'); $user->gravatar = Input::get('gravatar'); $user->locale = Input::get('locale'); if ((Gate::allows('self.two_factor')) && ((Setting::getSettings()->two_factor_enabled=='1') && (!config('app.lock_passwords')))) { $user->two_factor_optin = Input::get('two_factor_optin', '0'); } if (Input::file('avatar')) { $image = Input::file('avatar'); $file_name = str_slug($user->first_name."-".$user->last_name).".".$image->getClientOriginalExtension(); $path = public_path('uploads/avatars/'.$file_name); Image::make($image->getRealPath())->resize(84, 84)->save($path); $user->avatar = $file_name; } if (Input::get('avatar_delete') == 1 && Input::file('avatar') == "") { $user->avatar = null; } if ($user->save()) { return redirect()->route('profile')->with('success', 'Account successfully updated'); } return redirect()->back()->withInput()->withErrors($user->getErrors()); } /** * Returns a page with the API token generation interface. * * We created a controller method for this because closures aren't allowed * in the routes file if you want to be able to cache the routes. * * @author [A. Gianotto] [] * @since [v4.0] * @return View */ public function api() { return view('account/api'); } /** * User change email page. * * @return View */ public function password() { $user = Auth::user(); return view('account/change-password', compact('user')); } /** * Users change password form processing page. * * @return Redirect */ public function passwordSave(Request $request) { if (config('app.lock_passwords')) { return redirect()->route('account.password.index')->with('error', Lang::get('admin/users/table.lock_passwords')); } $user = Auth::user(); if ($user->ldap_import=='1') { return redirect()->route('account.password.index')->with('error', Lang::get('admin/users/message.error.password_ldap')); } $rules = array( 'current_password' => 'required', 'password' => 'required|min:6', 'password_confirm' => 'required|same:password', ); $validator = \Validator::make($request->all(), $rules); $validator->after(function($validator) use ($request, $user) { if (!Hash::check($request->input('current_password'), $user->password)) { $validator->errors()->add('current_password', trans('validation.hashed_pass')); } }); if (!$validator->fails()) { $user->password = Hash::make($request->input('password')); $user->save(); return redirect()->route('account.password.index')->with('success', 'Password updated!'); } return redirect()->back()->withInput()->withErrors($validator); } }