middleware('guest'); } /** * Get a validator for an incoming registration request. * * @param array $data * @return \Illuminate\Contracts\Validation\Validator */ protected function validator(array $data) { return Validator::make($data, [ 'name' => ['required', 'string', 'min:3', 'max:255'], 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'], 'password' => ['required', 'string', 'min:8', 'confirmed'], 'token' => 'required|doorman:email', ]); } /** * Create a new user instance after a valid registration. * * @param array $data * @return User */ protected function create(array $data): User { $fields = [ 'name' => $data['name'], 'email' => $data['email'], 'password' => Hash::make($data['password']), ]; if (config('auth.providers.users.field','email') === 'username' && isset($data['username'])) { $fields['username'] = $data['username']; } try { Doorman::redeem($data['token'],$data['email']); // @todo Want to direct or display an appropriate error message (although the form validation does it anyway). } catch (DoormanException $e) { redirect('/error'); abort(403); } return User::create($fields); } }