RegisterController.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. <?php
  2. namespace App\Http\Controllers\Auth;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Http\Request;
  5. use App\Providers\RouteServiceProvider;
  6. use App\User;
  7. use Illuminate\Support\Facades\Validator;
  8. use Illuminate\Foundation\Auth\RegistersUsers;
  9. use Illuminate\Support\Facades\Mail;
  10. use Illuminate\Support\Facades\Hash;
  11. //use App\Mail\SignUp;
  12. use App\Models\ReferUser;
  13. use Auth;
  14. class RegisterController extends Controller
  15. {
  16. /*
  17. |--------------------------------------------------------------------------
  18. | Register Controller
  19. |--------------------------------------------------------------------------
  20. |
  21. | This controller handles the registration of new users as well as their
  22. | validation and creation. By default this controller uses a trait to
  23. | provide this functionality without requiring any additional code.
  24. |
  25. */
  26. // use RegistersUsers;
  27. /**
  28. * Where to redirect users after registration.
  29. *
  30. * @var string
  31. */
  32. //protected $redirectTo = RouteServiceProvider::HOME;
  33. /**
  34. * Create a new controller instance.
  35. *
  36. * @return void
  37. */
  38. public function __construct()
  39. {
  40. $this->middleware('guest');
  41. }
  42. /**
  43. * Get a validator for an incoming registration request.
  44. *
  45. * @param array $data
  46. * @return \Illuminate\Contracts\Validation\Validator
  47. */
  48. protected function validator(array $data)
  49. {
  50. // if($data['user_type']==1){
  51. return Validator::make($data, [
  52. 'givenname' => ['required', 'string', 'max:255'],
  53. 'familyname' => ['required', 'string', 'max:255'],
  54. 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
  55. 'password' => ['required', 'string', 'min:8', 'confirmed'],
  56. 'nationality' => ['required', 'string','max:255'],
  57. 'dob' => ['required', 'string','date'],
  58. 'optradio' => ['required', 'string','max:255'],
  59. ]);
  60. // }
  61. }
  62. /**
  63. * Create a new user instance after a valid registration.
  64. *
  65. * @param array $data
  66. * @return \App\User
  67. */
  68. protected function create(Request $req)
  69. {
  70. //if($data['user_type']==1){
  71. $data = User::create([
  72. 'first_name' => $req->givenname,
  73. 'last_name' => $req->familyname,
  74. 'email' => $req->email,
  75. 'nationality' => $req->nationality,
  76. 'dob' => \Carbon\Carbon::parse($req->dob)->format('Y-m-d'),
  77. 'gender' => $req->optradio,
  78. 'user_type' => $req->user_type,
  79. 'password' => Hash::make($req->password),
  80. 'status' => 1,
  81. ]);
  82. $refer_user_exists = ReferUser::where('email',$req->email)->first();
  83. if($refer_user_exists){
  84. $refer_user_exists->signup =1;
  85. $refer_user_exists->update();
  86. }
  87. //Mail::to('test@mail.com')->send(new SignUp($data->id));
  88. return redirect()->to("/login")->with('success','Your registration successfully saved.');
  89. //}
  90. }
  91. public function showRegistrationForm()
  92. {
  93. return view('auth.register');
  94. }
  95. public function email_verification($id)
  96. {
  97. $data = User::find($id);
  98. $data->email_verification=1;
  99. $data->update();
  100. return Redirect('/login')->with('success','Your mail is activated successfully. Login here ');
  101. }
  102. }