ProfileController.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  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. return view('profile.index')->with([
  16. 'user' => Auth::user(),
  17. 'credits_reward_after_verify_discord' => config('SETTINGS::USER:CREDITS_REWARD_AFTER_VERIFY_DISCORD'),
  18. 'force_email_verification' => config('SETTINGS::USER:FORCE_EMAIL_VERIFICATION'),
  19. 'force_discord_verification' => config('SETTINGS::USER:FORCE_DISCORD_VERIFICATION'),
  20. ]);
  21. }
  22. /** Update the specified resource in storage.
  23. * @param Request $request
  24. * @param int $id
  25. * @return RedirectResponse
  26. */
  27. public function update(Request $request, int $id)
  28. {
  29. //prevent other users from editing a user
  30. if ($id != Auth::user()->id) dd(401);
  31. $user = User::findOrFail($id);
  32. //update password if necessary
  33. if (!is_null($request->input('new_password'))) {
  34. //validate password request
  35. $request->validate([
  36. 'current_password' => [
  37. 'required',
  38. function ($attribute, $value, $fail) use ($user) {
  39. if (!Hash::check($value, $user->password)) {
  40. $fail('The ' . $attribute . ' is invalid.');
  41. }
  42. },
  43. ],
  44. 'new_password' => 'required|string|min:8',
  45. 'new_password_confirmation' => 'required|same:new_password'
  46. ]);
  47. //Update Users Password on Pterodactyl
  48. //Username,Mail,First and Lastname are required aswell
  49. $response = Pterodactyl::client()->patch('/application/users/'.$user->pterodactyl_id, [
  50. "password" => $request->input('new_password'),
  51. "username" => $request->input('name'),
  52. "first_name" => $request->input('name'),
  53. "last_name" => $request->input('name'),
  54. "email" => $request->input('email'),
  55. ]);
  56. if ($response->failed()) {
  57. throw ValidationException::withMessages([
  58. 'pterodactyl_error_message' => $response->toException()->getMessage(),
  59. 'pterodactyl_error_status' => $response->toException()->getCode()
  60. ]);
  61. }
  62. //update password
  63. $user->update([
  64. 'password' => Hash::make($request->input('new_password')),
  65. ]);
  66. }
  67. //validate request
  68. $request->validate([
  69. 'name' => 'required|min:4|max:30|alpha_num|unique:users,name,' . $id . ',id',
  70. 'email' => 'required|email|max:64|unique:users,email,' . $id . ',id',
  71. 'avatar' => 'nullable'
  72. ]);
  73. //update avatar
  74. if (!is_null($request->input('avatar'))) {
  75. $avatar = json_decode($request->input('avatar'));
  76. if ($avatar->input->size > 3000000) abort(500);
  77. $user->update([
  78. 'avatar' => $avatar->output->image,
  79. ]);
  80. } else {
  81. $user->update([
  82. 'avatar' => null,
  83. ]);
  84. }
  85. //update name and email on Pterodactyl
  86. $response = Pterodactyl::client()->patch('/application/users/'.$user->pterodactyl_id, [
  87. "username" => $request->input('name'),
  88. "first_name" => $request->input('name'),
  89. "last_name" => $request->input('name'),
  90. "email" => $request->input('email'),
  91. ]);
  92. if ($response->failed()) {
  93. throw ValidationException::withMessages([
  94. 'pterodactyl_error_message' => $response->toException()->getMessage(),
  95. 'pterodactyl_error_status' => $response->toException()->getCode()
  96. ]);
  97. }
  98. //update name and email
  99. $user->update([
  100. 'name' => $request->input('name'),
  101. 'email' => $request->input('email'),
  102. ]);
  103. $user->sendEmailVerificationNotification();
  104. return redirect()->route('profile.index')->with('success', __('Profile updated'));
  105. }
  106. }