RegisterController.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Http\Controllers\Auth;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\UserStoreRequest;
  5. use App\Models\User;
  6. use Illuminate\Auth\Events\Registered;
  7. use Illuminate\Foundation\Auth\RegistersUsers;
  8. use Illuminate\Support\Facades\Hash;
  9. use Illuminate\Support\Facades\Log;
  10. class RegisterController extends Controller
  11. {
  12. /*
  13. |--------------------------------------------------------------------------
  14. | Register Controller
  15. |--------------------------------------------------------------------------
  16. |
  17. | This controller handles the registration of new users as well as their
  18. | validation and creation. By default this controller uses a trait to
  19. | provide this functionality without requiring any additional code.
  20. |
  21. */
  22. use RegistersUsers;
  23. /**
  24. * Handle a registration request for the application.
  25. *
  26. * @param \App\Http\Requests\UserStoreRequest $request
  27. * @return \Illuminate\Http\JsonResponse
  28. */
  29. public function register(UserStoreRequest $request)
  30. {
  31. $validated = $request->validated();
  32. event(new Registered($user = $this->create($validated)));
  33. Log::info('User created');
  34. $this->guard()->login($user);
  35. return response()->json([
  36. 'message' => 'account created',
  37. 'name' => $user->name,
  38. ], 201);
  39. }
  40. /**
  41. * Create a new user instance after a valid registration.
  42. *
  43. * @param array $data
  44. * @return \App\Models\User
  45. */
  46. protected function create(array $data)
  47. {
  48. return User::create([
  49. 'name' => $data['name'],
  50. 'email' => $data['email'],
  51. 'password' => Hash::make($data['password']),
  52. ]);
  53. }
  54. }