RegisterController.php 1.7 KB

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