RegisterController.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. <?php
  2. namespace App\Http\Controllers\Auth;
  3. use App\Classes\Pterodactyl;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\Settings;
  6. use App\Models\User;
  7. use App\Notifications\ReferralNotification;
  8. use App\Providers\RouteServiceProvider;
  9. use Carbon\Carbon;
  10. use Illuminate\Foundation\Auth\RegistersUsers;
  11. use Illuminate\Support\Facades\App;
  12. use Illuminate\Support\Facades\Auth;
  13. use Illuminate\Support\Facades\DB;
  14. use Illuminate\Support\Facades\Hash;
  15. use Illuminate\Support\Facades\Validator;
  16. use Illuminate\Support\Str;
  17. use Illuminate\Validation\ValidationException;
  18. class RegisterController extends Controller
  19. {
  20. /*
  21. |--------------------------------------------------------------------------
  22. | Register Controller
  23. |--------------------------------------------------------------------------
  24. |
  25. | This controller handles the registration of new users as well as their
  26. | validation and creation. By default this controller uses a trait to
  27. | provide this functionality without requiring any additional code.
  28. |
  29. */
  30. use RegistersUsers;
  31. /**
  32. * Where to redirect users after registration.
  33. *
  34. * @var string
  35. */
  36. protected $redirectTo = RouteServiceProvider::HOME;
  37. /**
  38. * Create a new controller instance.
  39. *
  40. * @return void
  41. */
  42. public function __construct()
  43. {
  44. $this->middleware('guest');
  45. }
  46. /**
  47. * Get a validator for an incoming registration request.
  48. *
  49. * @param array $data
  50. * @return \Illuminate\Contracts\Validation\Validator
  51. */
  52. protected function validator(array $data)
  53. {
  54. $validationRules = [
  55. 'name' => ['required', 'string', 'max:30', 'min:4', 'alpha_num', 'unique:users'],
  56. 'email' => ['required', 'string', 'email', 'max:64', 'unique:users'],
  57. 'password' => ['required', 'string', 'min:8', 'confirmed'],
  58. ];
  59. if (config('SETTINGS::RECAPTCHA:ENABLED') == 'true') {
  60. $validationRules['g-recaptcha-response'] = ['required', 'recaptcha'];
  61. }
  62. if (config('SETTINGS::SYSTEM:REGISTER_IP_CHECK', 'true') == 'true') {
  63. //check if ip has already made an account
  64. $data['ip'] = session()->get('ip') ?? request()->ip();
  65. if (User::where('ip', '=', request()->ip())->exists()) session()->put('ip', request()->ip());
  66. $validationRules['ip'] = ['unique:users'];
  67. return Validator::make($data, $validationRules, [
  68. 'ip.unique' => "You have already made an account! Please contact support if you think this is incorrect."
  69. ]);
  70. }
  71. return Validator::make($data, $validationRules);
  72. }
  73. /**
  74. * Create a unique Referral Code for User
  75. * @return string
  76. */
  77. protected function createReferralCode(){
  78. $referralcode = STR::random(8);
  79. if (User::where('referral_code', '=', $referralcode)->exists()) {
  80. $this->createReferralCode();
  81. }
  82. return $referralcode;
  83. }
  84. /**
  85. * Create a new user instance after a valid registration.
  86. *
  87. * @param array $data
  88. * @return User
  89. */
  90. protected function create(array $data)
  91. {
  92. $user = User::create([
  93. 'name' => $data['name'],
  94. 'email' => $data['email'],
  95. 'credits' => config('SETTINGS::USER:INITIAL_CREDITS', 150),
  96. 'server_limit' => config('SETTINGS::USER:INITIAL_SERVER_LIMIT', 1),
  97. 'password' => Hash::make($data['password']),
  98. 'referral_code' => $this->createReferralCode(),
  99. ]);
  100. $response = Pterodactyl::client()->post('/application/users', [
  101. "external_id" => App::environment('local') ? Str::random(16) : (string)$user->id,
  102. "username" => $user->name,
  103. "email" => $user->email,
  104. "first_name" => $user->name,
  105. "last_name" => $user->name,
  106. "password" => $data['password'],
  107. "root_admin" => false,
  108. "language" => "en"
  109. ]);
  110. if ($response->failed()) {
  111. $user->delete();
  112. throw ValidationException::withMessages([
  113. 'ptero_registration_error' => [__('Account already exists on Pterodactyl. Please contact the Support!')],
  114. ]);
  115. }
  116. $user->update([
  117. 'pterodactyl_id' => $response->json()['attributes']['id']
  118. ]);
  119. //INCREMENT REFERRAL-USER CREDITS
  120. if(!empty($data['referral_code'])){
  121. $ref_code = $data['referral_code'];
  122. $new_user = $user->id;
  123. if($ref_user = User::query()->where('referral_code', '=', $ref_code)->first()) {
  124. if(config("SETTINGS::REFERRAL:MODE" == "sign-up") || config("SETTINGS::REFERRAL:MODE" == "both")) {
  125. $ref_user->increment('credits', config("SETTINGS::REFERRAL::REWARD"));
  126. $ref_user->notify(new ReferralNotification($ref_user->id, $new_user));
  127. }
  128. //INSERT INTO USER_REFERRALS TABLE
  129. DB::table('user_referrals')->insert([
  130. 'referral_id' => $ref_user->id,
  131. 'registered_user_id' => $user->id,
  132. 'created_at' => Carbon::now(),
  133. 'updated_at' => Carbon::now()
  134. ]);
  135. }
  136. }
  137. return $user;
  138. }
  139. }