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', 'max:255'], 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'], 'password' => ['required', 'string', 'min:8', 'confirmed'], ]); } /** * Create a new user instance after a valid registration. * * @param array $data * @return \App\User */ protected function create(array $data) { if (Dashboard::canRegister()) { return User::create([ 'name' => $data['name'], 'email' => $data['email'], 'password' => Hash::make($data['password']), 'api_token' => str_random(60) ]); } else { abort(404); } } /** * Show the application registration form. * * @return \Illuminate\Http\Response */ public function showRegistrationForm() { if (Dashboard::canRegister()) { return view('auth.register'); } else { header('Location: /login'); } } }