RegisterController.php 3.4 KB

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