ProfileController.php 5.3 KB

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