RegisterController.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. namespace App\Http\Controllers\Auth;
  3. use App\User;
  4. use Illuminate\Http\Request;
  5. use Illuminate\Support\Facades\DB;
  6. use App\Http\Controllers\Controller;
  7. use Illuminate\Support\Facades\Hash;
  8. use Illuminate\Auth\Events\Registered;
  9. use Illuminate\Support\Facades\Validator;
  10. use Illuminate\Foundation\Auth\RegistersUsers;
  11. class RegisterController extends Controller
  12. {
  13. /*
  14. |--------------------------------------------------------------------------
  15. | Register Controller
  16. |--------------------------------------------------------------------------
  17. |
  18. | This controller handles the registration of new users as well as their
  19. | validation and creation. By default this controller uses a trait to
  20. | provide this functionality without requiring any additional code.
  21. |
  22. */
  23. use RegistersUsers;
  24. /**
  25. * check if a user exists
  26. * @param Request $request [description]
  27. * @return json
  28. */
  29. public function checkUser()
  30. {
  31. $count = DB::table('users')->count();
  32. $username = DB::table('users')->where('id', 1)->value('name');
  33. if( $count === 1 ) {
  34. return response()->json(['userCount' => $count, 'username' => $username], 200);
  35. }
  36. else {
  37. return response()->json(['userCount' => $count], 200);
  38. }
  39. }
  40. /**
  41. * Handle a registration request for the application.
  42. *
  43. * @param \Illuminate\Http\Request $request
  44. * @return \Illuminate\Http\JsonResponse
  45. */
  46. public function register(Request $request)
  47. {
  48. // check if a user already exists
  49. if( DB::table('users')->count() > 0 ) {
  50. // return response()->json(['message' => __('errors.already_one_user_registered')], 400);
  51. throw \Illuminate\Validation\ValidationException::withMessages(['taken' => __('errors.already_one_user_registered')]);
  52. }
  53. $this->validator($request->all())->validate();
  54. event(new Registered($user = $this->create($request->all())));
  55. //$this->guard()->login($user);
  56. $success['token'] = $user->createToken('MyApp')->accessToken;
  57. $success['name'] = $user->name;
  58. return response()->json(['message' => $success]);
  59. // return $this->registered($request, $user)
  60. // ?: redirect($this->redirectPath());
  61. }
  62. /**
  63. * Get a validator for an incoming registration request.
  64. *
  65. * @param array $data
  66. * @return \Illuminate\Contracts\Validation\Validator
  67. */
  68. protected function validator(array $data)
  69. {
  70. return Validator::make($data, [
  71. 'name' => ['required', 'string', 'max:255'],
  72. 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
  73. 'password' => ['required', 'string', 'min:8', 'confirmed'],
  74. ]);
  75. }
  76. /**
  77. * Create a new user instance after a valid registration.
  78. *
  79. * @param array $data
  80. * @return \App\User
  81. */
  82. protected function create(array $data)
  83. {
  84. return User::create([
  85. 'name' => $data['name'],
  86. 'email' => $data['email'],
  87. 'password' => Hash::make($data['password']),
  88. ]);
  89. }
  90. }