<?php namespace App\Http\Controllers\Auth; use App\User; use App\Http\Requests\UserStoreRequest; use Illuminate\Http\Request; use Illuminate\Support\Facades\DB; use App\Http\Controllers\Controller; use Illuminate\Support\Facades\Hash; use Illuminate\Auth\Events\Registered; use Illuminate\Support\Facades\Validator; use Illuminate\Foundation\Auth\RegistersUsers; use Illuminate\Validation\ValidationException; class RegisterController extends Controller { /* |-------------------------------------------------------------------------- | Register Controller |-------------------------------------------------------------------------- | | This controller handles the registration of new users as well as their | validation and creation. By default this controller uses a trait to | provide this functionality without requiring any additional code. | */ use RegistersUsers; /** * Handle a registration request for the application. * * @param \App\Http\Requests\UserStoreRequest $request * @return \Illuminate\Http\JsonResponse */ public function register(UserStoreRequest $request) { $validated = $request->validated(); event(new Registered($user = $this->create($validated))); return response()->json([ 'message' => 'account created', 'token' => $user->createToken('2FAuth')->accessToken, 'name' => $user->name, ], 201); } /** * 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']), ]); } }