RegisterController.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. namespace App\Http\Controllers\TeacherAuth;
  3. use Validator;
  4. use App\Http\Controllers\Controller;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Foundation\Auth\RegistersUsers;
  7. use Illuminate\Support\Facades\Auth;
  8. use App\Mail\SignUp;
  9. use App\User;
  10. use Hash;
  11. use Mail;
  12. class RegisterController extends Controller
  13. {
  14. /*
  15. |--------------------------------------------------------------------------
  16. | Register Controller
  17. |--------------------------------------------------------------------------
  18. |
  19. | This controller handles the registration of new users as well as their
  20. | validation and creation. By default this controller uses a trait to
  21. | provide this functionality without requiring any additional code.
  22. |
  23. */
  24. //use RegistersUsers;
  25. /**
  26. * Where to redirect users after login / registration.
  27. *
  28. * @var string
  29. */
  30. //protected $redirectTo = '/login-v2';
  31. /**
  32. * Create a new controller instance.
  33. *
  34. * @return void
  35. */
  36. public function __construct()
  37. {
  38. $this->middleware('teacher.guest');
  39. }
  40. protected function validator(array $data)
  41. {
  42. return Validator::make($data, [
  43. 'firstname' => ['required', 'string', 'max:255'],
  44. 'lastname' => ['required', 'string', 'max:255'],
  45. 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
  46. 'password' => ['required', 'string', 'min:8', 'confirmed'],
  47. //'phonenumber' => ['required', 'string', 'max:255'],
  48. 'universityname' => ['required', 'string', 'max:255'],
  49. 'department' => ['required', 'string', 'max:255'],
  50. 'designation' => ['required', 'string', 'max:255'],
  51. 'universitywebsite' => ['required', 'string', 'max:255'],
  52. ]);
  53. }
  54. /**
  55. * Create a new user instance after a valid registration.
  56. *
  57. * @param array $data
  58. * @return User
  59. */
  60. protected function create(Request $req)
  61. {
  62. $data = User::create([
  63. 'first_name' => $req->firstname,
  64. 'last_name' => $req->lastname,
  65. 'password' => Hash::make($req->password),
  66. 'email' => $req->email,
  67. // 'phone_number' => $req->phonenumber,
  68. 'university_name' => $req->universityname,
  69. 'department' => $req->department,
  70. 'designation' => $req->designation,
  71. 'uni_website' => $req->universitywebsite,
  72. 'user_type' => $req->user_type,
  73. 'ref_no' => name_initials($req->firstname,$req->lastname).''.teacherRefNoGenerate(),
  74. ]);
  75. Mail::to('test@mail.com')->send(new SignUp($data->id));
  76. return redirect()->to("/login-v2");
  77. }
  78. /**
  79. * Show the application registration form.
  80. *
  81. * @return \Illuminate\Http\Response
  82. */
  83. public function showRegistrationForm()
  84. {
  85. return view('register-v2');
  86. }
  87. /**
  88. * Get the guard to be used during registration.
  89. *
  90. * @return \Illuminate\Contracts\Auth\StatefulGuard
  91. */
  92. protected function guard()
  93. {
  94. return Auth::guard('teacher');
  95. }
  96. }