web-mooc/app/Http/Controllers/Auth/VerifyEmailController.php

43 lines
1.3 KiB
PHP

<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Providers\RouteServiceProvider;
use Illuminate\Auth\Events\Verified;
use Illuminate\Foundation\Auth\EmailVerificationRequest;
use Illuminate\Http\RedirectResponse;
use Illuminate\Support\Facades\Auth;
use App\Models\User;
class VerifyEmailController extends Controller
{
/**
* Mark the authenticated user's email address as verified.
*/
public function __invoke(EmailVerificationRequest $request): RedirectResponse
{
// If you need to manually handle user authentication, do it here
// But note: Laravel should already handle this with EmailVerificationRequest
$user = $request->user();
if (!$user) {
// Fallback: try to get user from route parameters if not authenticated
$user = User::find($request->route('id'));
if ($user) {
Auth::login($user);
}
}
if ($user->hasVerifiedEmail()) {
return redirect()->intended(RouteServiceProvider::HOME . '?verified=1');
}
if ($user->markEmailAsVerified()) {
event(new Verified($user));
}
return redirect()->intended(RouteServiceProvider::HOME . '?verified=1');
}
}