first(); return response()->json(['username' => isset($user->name) ? $user->name : null], 200); } /** * Handle a registration request for the application. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\JsonResponse */ public function register(Request $request) { // check if a user already exists if( DB::table('users')->count() > 0 ) { // return response()->json(['message' => __('errors.already_one_user_registered')], 400); throw \Illuminate\Validation\ValidationException::withMessages(['taken' => __('errors.already_one_user_registered')]); } $this->validator($request->all())->validate(); event(new Registered($user = $this->create($request->all()))); //$this->guard()->login($user); return response()->json([ 'message' => 'account created', 'token' => $user->createToken('MyApp')->accessToken, 'name' => $user->name, ]); } /** * 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) { return User::create([ 'name' => $data['name'], 'email' => $data['email'], 'password' => Hash::make($data['password']), ]); } }