Files

75 lines
1.9 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Http\Requests\ProfileUpdateRequest;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Redirect;
use Illuminate\Support\Facades\Storage;
use Inertia\Inertia;
use Inertia\Response;
class ProfileController extends Controller
{
/**
* Display the user's profile form (Redirect to consolidated settings).
*/
public function edit(Request $request): RedirectResponse
{
return Redirect::route('settings.index');
}
/**
* Update the user's profile information and avatar.
*/
public function update(ProfileUpdateRequest $request): RedirectResponse
{
$user = $request->user();
$user->fill($request->validated());
if ($user->isDirty('email')) {
$user->email_verified_at = null;
}
// Handle Avatar Upload
if ($request->hasFile('avatar_file')) {
// Delete old avatar if exists
if ($user->avatar_url) {
$oldPath = str_replace('/storage/', '', $user->avatar_url);
Storage::disk('public')->delete($oldPath);
}
$path = $request->file('avatar_file')->store('avatars', 'public');
$user->avatar_url = Storage::url($path);
}
$user->save();
return Redirect::route('settings.index')->with('status', 'profile-updated');
}
/**
* Delete the user's account.
*/
public function destroy(Request $request): RedirectResponse
{
$request->validate([
'password' => ['required', 'current_password'],
]);
$user = $request->user();
Auth::logout();
$user->delete();
$request->session()->invalidate();
$request->session()->regenerateToken();
return Redirect::to('/');
}
}