middleware('guest'); } /** * Get a validator for an incoming registration request. * * @param array $data * @return \Illuminate\Contracts\Validation\Validator */ protected function validator(Request $request) { return Validator::make( $request->all(), [ 'name' => 'required|max:255', 'email' => 'required|email|max:255|unique:users', 'password' => 'required|min:6|confirmed', ] ) ->after(function($validator) use ($request) { // reCAPTCHA validation if ( UserConfig::get('recaptcha_enabled_registration') && !RecaptchaHelper::validateResponse($request->request->get('g-recaptcha-response'), $request->getClientIp()) ) { $validator->errors()->add('recaptcha', trans('auth.recaptcha_failed_message')); } }); } /** * Create a new user instance after a valid registration. * * @param array $data * @return User */ protected function create(array $data) { $activationData = [ 'is_activated' => true ]; if (UserConfig::get('require_email_verification')) { $activationData['is_activated'] = false; $activationData['activation_token'] = MiscHelper::randomString(); } return User::create(array_merge( [ 'name' => $data['name'], 'email' => $data['email'], 'password' => bcrypt($data['password']), 'is_admin' => false ], $activationData )); } public function register(Request $request) { if (!UserConfig::get('allow_self_registration')) { return redirect(route('home')); } $this->validator($request)->validate(); /** @var User $user */ $user = $this->create($request->all()); if ($user->is_activated) { $this->guard()->login($user); } else { // Send activation e-mail Mail::to($user)->send(new UserActivationRequired($user)); $request->session()->flash('info', trans('auth.activation_required_message')); } return redirect($this->redirectPath()); } /** * Show the application registration form. * * @return \Illuminate\Http\Response */ public function showRegistrationForm() { if (!UserConfig::get('allow_self_registration')) { return redirect(route('home')); } return Theme::render('auth.register'); } }