RegisterController.php 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. namespace App\Http\Controllers\AdminAuth;
  3. use App\Admin;
  4. use Validator;
  5. use App\Http\Controllers\Controller;
  6. use Illuminate\Foundation\Auth\RegistersUsers;
  7. use Illuminate\Support\Facades\Auth;
  8. class RegisterController extends Controller
  9. {
  10. /*
  11. |--------------------------------------------------------------------------
  12. | Register Controller
  13. |--------------------------------------------------------------------------
  14. |
  15. | This controller handles the registration of new users as well as their
  16. | validation and creation. By default this controller uses a trait to
  17. | provide this functionality without requiring any additional code.
  18. |
  19. */
  20. use RegistersUsers;
  21. /**
  22. * Where to redirect users after login / registration.
  23. *
  24. * @var string
  25. */
  26. protected $redirectTo = '/admin/home';
  27. /**
  28. * Create a new controller instance.
  29. *
  30. * @return void
  31. */
  32. public function __construct()
  33. {
  34. $this->middleware('admin.guest');
  35. }
  36. /**
  37. * Get a validator for an incoming registration request.
  38. *
  39. * @param array $data
  40. * @return \Illuminate\Contracts\Validation\Validator
  41. */
  42. protected function validator(array $data)
  43. {
  44. return Validator::make($data, [
  45. 'name' => 'required|max:255',
  46. 'email' => 'required|email|max:255|unique:admins',
  47. 'password' => 'required|min:6|confirmed',
  48. ]);
  49. }
  50. /**
  51. * Create a new user instance after a valid registration.
  52. *
  53. * @param array $data
  54. * @return Admin
  55. */
  56. protected function create(array $data)
  57. {
  58. return Admin::create([
  59. 'name' => $data['name'],
  60. 'email' => $data['email'],
  61. 'password' => bcrypt($data['password']),
  62. ]);
  63. }
  64. /**
  65. * Show the application registration form.
  66. *
  67. * @return \Illuminate\Http\Response
  68. */
  69. public function showRegistrationForm()
  70. {
  71. return view('admin.auth.register');
  72. }
  73. /**
  74. * Get the guard to be used during registration.
  75. *
  76. * @return \Illuminate\Contracts\Auth\StatefulGuard
  77. */
  78. protected function guard()
  79. {
  80. return Auth::guard('admin');
  81. }
  82. }