openclassify/app/Http/Controllers/Auth/ProfileController.php
GitHub Copilot 067db6eaa2 Fix auth routes, profile management, and test failures
Co-authored-by: fatihalp <219454+fatihalp@users.noreply.github.com>
2026-03-02 23:46:32 +00:00

55 lines
1.4 KiB
PHP

<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Validation\Rule;
class ProfileController extends Controller
{
/**
* Update the user's profile information.
*/
public function update(Request $request): RedirectResponse
{
$validated = $request->validateWithBag('updateProfile', [
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'string', 'lowercase', 'email', 'max:255', Rule::unique('users')->ignore($request->user()->id)],
]);
$request->user()->fill($validated);
if ($request->user()->isDirty('email')) {
$request->user()->email_verified_at = null;
}
$request->user()->save();
return redirect('/profile')->with('status', 'profile-updated');
}
/**
* Delete the user's account.
*/
public function destroy(Request $request): RedirectResponse
{
$request->validateWithBag('userDeletion', [
'password' => ['required', 'current_password'],
]);
$user = $request->user();
Auth::logout();
$user->delete();
$request->session()->invalidate();
$request->session()->regenerateToken();
return redirect('/');
}
}