ProfileController.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\User;
  4. use App\Settings\UserSettings;
  5. use App\Settings\PterodactylSettings;
  6. use App\Classes\PterodactylClient;
  7. use App\Settings\DiscordSettings;
  8. use App\Settings\ReferralSettings;
  9. use Illuminate\Http\RedirectResponse;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Support\Facades\Auth;
  12. use Illuminate\Support\Facades\Hash;
  13. use Illuminate\Validation\ValidationException;
  14. class ProfileController extends Controller
  15. {
  16. private $pterodactyl;
  17. public function __construct(PterodactylSettings $ptero_settings)
  18. {
  19. $this->pterodactyl = new PterodactylClient($ptero_settings);
  20. }
  21. /** Display a listing of the resource. */
  22. public function index(UserSettings $user_settings, DiscordSettings $discord_settings, ReferralSettings $referral_settings)
  23. {
  24. switch (Auth::user()->role) {
  25. case 'admin':
  26. $badgeColor = 'badge-danger';
  27. break;
  28. case 'mod':
  29. $badgeColor = 'badge-info';
  30. break;
  31. case 'client':
  32. $badgeColor = 'badge-success';
  33. break;
  34. default:
  35. $badgeColor = 'badge-secondary';
  36. break;
  37. }
  38. return view('profile.index')->with([
  39. 'user' => Auth::user(),
  40. 'credits_reward_after_verify_discord' => $user_settings->credits_reward_after_verify_discord,
  41. 'force_email_verification' => $user_settings->force_email_verification,
  42. 'force_discord_verification' => $user_settings->force_discord_verification,
  43. 'badgeColor' => $badgeColor,
  44. 'discord_client_id' => $discord_settings->client_id,
  45. 'discord_client_secret' => $discord_settings->client_secret,
  46. 'referral_enabled' => $referral_settings->enabled,
  47. 'referral_allowed' => $referral_settings->allowed
  48. ]);
  49. }
  50. public function selfDestroyUser()
  51. {
  52. $user = Auth::user();
  53. if ($user->role == "admin") return back()->with("error", "You cannot delete yourself as an admin!");
  54. $user->delete();
  55. return redirect('/login')->with('success', __('Account permanently deleted!'));
  56. }
  57. /** Update the specified resource in storage.
  58. * @param Request $request
  59. * @param int $id
  60. * @return RedirectResponse
  61. */
  62. public function update(Request $request, int $id)
  63. {
  64. //prevent other users from editing a user
  65. if ($id != Auth::user()->id) {
  66. dd(401);
  67. }
  68. $user = User::findOrFail($id);
  69. //update password if necessary
  70. if (!is_null($request->input('new_password'))) {
  71. //validate password request
  72. $request->validate([
  73. 'current_password' => [
  74. 'required',
  75. function ($attribute, $value, $fail) use ($user) {
  76. if (!Hash::check($value, $user->password)) {
  77. $fail('The ' . $attribute . ' is invalid.');
  78. }
  79. },
  80. ],
  81. 'new_password' => 'required|string|min:8',
  82. 'new_password_confirmation' => 'required|same:new_password',
  83. ]);
  84. //Update Users Password on Pterodactyl
  85. //Username,Mail,First and Lastname are required aswell
  86. $response = $this->pterodactyl->application->patch('/application/users/' . $user->pterodactyl_id, [
  87. 'password' => $request->input('new_password'),
  88. 'username' => $request->input('name'),
  89. 'first_name' => $request->input('name'),
  90. 'last_name' => $request->input('name'),
  91. 'email' => $request->input('email'),
  92. ]);
  93. if ($response->failed()) {
  94. throw ValidationException::withMessages([
  95. 'pterodactyl_error_message' => $response->toException()->getMessage(),
  96. 'pterodactyl_error_status' => $response->toException()->getCode(),
  97. ]);
  98. }
  99. //update password
  100. $user->update([
  101. 'password' => Hash::make($request->input('new_password')),
  102. ]);
  103. }
  104. //validate request
  105. $request->validate([
  106. 'name' => 'required|min:4|max:30|alpha_num|unique:users,name,' . $id . ',id',
  107. 'email' => 'required|email|max:64|unique:users,email,' . $id . ',id',
  108. 'avatar' => 'nullable',
  109. ]);
  110. //update avatar
  111. if (!is_null($request->input('avatar'))) {
  112. $avatar = json_decode($request->input('avatar'));
  113. if ($avatar->input->size > 3000000) {
  114. abort(500);
  115. }
  116. $user->update([
  117. 'avatar' => $avatar->output->image,
  118. ]);
  119. } else {
  120. $user->update([
  121. 'avatar' => null,
  122. ]);
  123. }
  124. //update name and email on Pterodactyl
  125. $response = $this->pterodactyl->application->patch('/application/users/' . $user->pterodactyl_id, [
  126. 'username' => $request->input('name'),
  127. 'first_name' => $request->input('name'),
  128. 'last_name' => $request->input('name'),
  129. 'email' => $request->input('email'),
  130. ]);
  131. if ($response->failed()) {
  132. throw ValidationException::withMessages([
  133. 'pterodactyl_error_message' => $response->toException()->getMessage(),
  134. 'pterodactyl_error_status' => $response->toException()->getCode(),
  135. ]);
  136. }
  137. //update name and email
  138. $user->update([
  139. 'name' => $request->input('name'),
  140. 'email' => $request->input('email'),
  141. ]);
  142. if ($request->input('email') != Auth::user()->email) {
  143. $user->reVerifyEmail();
  144. $user->sendEmailVerificationNotification();
  145. }
  146. return redirect()->route('profile.index')->with('success', __('Profile updated'));
  147. }
  148. }