43 lines
1.3 KiB
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');
|
|
}
|
|
} |