RegisterController.php 5.6 KB

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