ctrlpanel/app/Http/Controllers/ProfileController.php

155 lines
5.4 KiB
PHP
Raw Normal View History

2021-06-05 09:26:32 +00:00
<?php
namespace App\Http\Controllers;
use App\Models\User;
2023-02-04 16:40:42 +00:00
use App\Settings\UserSettings;
2023-02-06 20:16:54 +00:00
use App\Settings\PterodactylSettings;
use App\Classes\PterodactylClient;
use App\Settings\DiscordSettings;
use App\Settings\ReferralSettings;
2021-06-05 09:26:32 +00:00
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
2021-12-27 07:39:50 +00:00
use Illuminate\Validation\ValidationException;
2021-06-05 09:26:32 +00:00
class ProfileController extends Controller
{
2023-02-06 20:16:54 +00:00
private $pterodactyl;
public function __construct(PterodactylSettings $ptero_settings)
{
$this->pterodactyl = new PterodactylClient($ptero_settings);
}
2021-06-06 18:17:52 +00:00
/** Display a listing of the resource. */
2023-02-06 20:16:54 +00:00
public function index(UserSettings $user_settings, DiscordSettings $discord_settings, ReferralSettings $referral_settings)
2021-06-05 09:26:32 +00:00
{
2021-06-05 09:26:32 +00:00
return view('profile.index')->with([
'user' => Auth::user(),
2023-02-04 16:40:42 +00:00
'credits_reward_after_verify_discord' => $user_settings->credits_reward_after_verify_discord,
'force_email_verification' => $user_settings->force_email_verification,
'force_discord_verification' => $user_settings->force_discord_verification,
2023-02-06 20:16:54 +00:00
'discord_client_id' => $discord_settings->client_id,
'discord_client_secret' => $discord_settings->client_secret,
2023-05-17 16:17:51 +00:00
'referral_enabled' => $referral_settings->enabled
2021-06-05 09:26:32 +00:00
]);
}
public function selfDestroyUser()
{
$user = Auth::user();
if ($user->hasRole("Admin")) return back()->with("error", "You cannot delete yourself as an admin!");
2023-01-02 14:00:57 +00:00
$user->delete();
2023-01-02 14:00:57 +00:00
return redirect('/login')->with('success', __('Account permanently deleted!'));
2023-01-02 14:00:57 +00:00
}
/** Update the specified resource in storage.
* @param Request $request
* @param int $id
* @return RedirectResponse
*/
2021-06-06 21:26:36 +00:00
public function update(Request $request, int $id)
2021-06-05 09:26:32 +00:00
{
//prevent other users from editing a user
if ($id != Auth::user()->id) {
dd(401);
}
2021-06-05 09:26:32 +00:00
$user = User::findOrFail($id);
//update password if necessary
if (!is_null($request->input('new_password'))) {
2021-06-05 09:26:32 +00:00
//validate password request
$request->validate([
'current_password' => [
'required',
2021-06-05 09:26:32 +00:00
function ($attribute, $value, $fail) use ($user) {
if (!Hash::check($value, $user->password)) {
$fail('The ' . $attribute . ' is invalid.');
2021-06-05 09:26:32 +00:00
}
},
],
'new_password' => 'required|string|min:8',
'new_password_confirmation' => 'required|same:new_password',
2021-06-05 09:26:32 +00:00
]);
2021-12-27 07:39:50 +00:00
//Update Users Password on Pterodactyl
//Username,Mail,First and Lastname are required aswell
$response = $this->pterodactyl->application->patch('/application/users/' . $user->pterodactyl_id, [
'password' => $request->input('new_password'),
'username' => $request->input('name'),
'first_name' => $request->input('name'),
'last_name' => $request->input('name'),
'email' => $request->input('email'),
2021-12-27 07:39:50 +00:00
]);
if ($response->failed()) {
throw ValidationException::withMessages([
'pterodactyl_error_message' => $response->toException()->getMessage(),
'pterodactyl_error_status' => $response->toException()->getCode(),
2021-12-27 07:39:50 +00:00
]);
}
2021-06-05 09:26:32 +00:00
//update password
$user->update([
'password' => Hash::make($request->input('new_password')),
]);
}
//validate request
$request->validate([
'name' => 'required|min:4|max:30|alpha_num|unique:users,name,' . $id . ',id',
'email' => 'required|email|max:64|unique:users,email,' . $id . ',id',
'avatar' => 'nullable',
2021-06-05 09:26:32 +00:00
]);
//update avatar
if (!is_null($request->input('avatar'))) {
2021-06-05 09:26:32 +00:00
$avatar = json_decode($request->input('avatar'));
if ($avatar->input->size > 3000000) {
abort(500);
}
2021-06-05 09:26:32 +00:00
$user->update([
'avatar' => $avatar->output->image,
]);
} else {
$user->update([
'avatar' => null,
]);
}
2021-12-27 07:39:50 +00:00
//update name and email on Pterodactyl
$response = $this->pterodactyl->application->patch('/application/users/' . $user->pterodactyl_id, [
'username' => $request->input('name'),
'first_name' => $request->input('name'),
'last_name' => $request->input('name'),
'email' => $request->input('email'),
2021-12-27 07:39:50 +00:00
]);
if ($response->failed()) {
throw ValidationException::withMessages([
'pterodactyl_error_message' => $response->toException()->getMessage(),
'pterodactyl_error_status' => $response->toException()->getCode(),
2021-12-27 07:39:50 +00:00
]);
}
2021-06-05 09:26:32 +00:00
//update name and email
$user->update([
'name' => $request->input('name'),
'email' => $request->input('email'),
]);
if ($request->input('email') != Auth::user()->email) {
$user->reVerifyEmail();
$user->sendEmailVerificationNotification();
}
2022-11-03 19:32:06 +00:00
return redirect()->route('profile.index')->with('success', __('Profile updated'));
2021-06-05 09:26:32 +00:00
}
}