LARAVEL 8 : ENABLE EMAIL VERIFICATION FOR REGISTRATION
-------------------------------------------------------
(1) Modify the Verification controller found in
app > Http > Controllers > Auth > VerificationController
*Update below class;
FROM :
Class User Extends Authenticatable
{
...
}
TO :
Class User Extends Authenticatable implements MustVerifyEmail
{
...
}
(2) Add the below code in the web.php route file;
Auth::routes(['verify' => true]);
(3) Add the below code in the Middleware section of your Controllers
$this->middleware(['auth', 'verified']);
Thats all, the next registration will require an email confirmation
composer require beyondcode/laravel-confirm-email
Route::name('auth.resend_confirmation')->get('/register/confirm/resend', 'AuthRegisterController@resendConfirmation');
Route::name('auth.confirm')->get('/register/confirm/{confirmation_code}', 'AuthRegisterController@confirm');
<?php
namespace AppHttpMiddleware;
use Closure;
use IlluminateHttpRequest;
use IlluminateSupportFacadesAuth;
class IsVerifyEmail
{
/**
* Handle an incoming request.
*
* @param IlluminateHttpRequest $request
* @param Closure $next
* @return mixed
*/
public function handle(Request $request, Closure $next)
{
if (!Auth::user()->is_email_verified) {
auth()->logout();
return redirect()->route('login')
->with('message', 'You need to confirm your account. We have sent you an activation code, please check your email.');
}
return $next($request);
}
}
here I wroted:
https://medium.com/@axmedov/laravel-email-verification-during-registration-via-secret-key-9464a75be660
<?php
namespace AppHttpControllers;
use IlluminateHttpRequest;
use IlluminateFoundationAuthRedirectsUsers;
use IlluminateFoundationAuthVerifiesEmails;
class VerificationController extends Controller
{
/*
|--------------------------------------------------------------------------
| Email Verification Controller
|--------------------------------------------------------------------------
|
| This controller is responsible for handling email verification for any
| user that recently registered with the application. Emails may also
| be re-sent if the user didn't receive the original email message.
|
*/
use VerifiesEmails, RedirectsUsers;
/**
* Where to redirect users after verification.
*
* @var string
*/
protected $redirectTo = '/';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth');
$this->middleware('signed')->only('verify');
$this->middleware('throttle:6,1')->only('verify', 'resend');
}
/**
* Show the email verification notice.
*
* @param IlluminateHttpRequest $request
* @return IlluminateHttpRedirectResponse|IlluminateViewView
*/
public function show(Request $request)
{
return $request->user()->hasVerifiedEmail()
? redirect($this->redirectPath())
: view('verification.notice', [
'pageTitle' => __('Account Verification')
]);
}
}