route()->getName()=='two-factor') || ($request->route()->getName()=='two-factor-enroll') || ($request->route()->getPrefix()=='setup') || ($request->route()->getName()=='logout')) { return $next($request); } // Two-factor is enabled (either optional or required) if (Setting::getSettings()) { if (Auth::check() && (Setting::getSettings()->two_factor_enabled!='')) { // This user is already 2fa-authed if ($request->session()->get('2fa_authed')) { return $next($request); } // Two-factor is optional and the user has NOT opted in, let them through if ((Setting::getSettings()->two_factor_enabled=='1') && (Auth::user()->two_factor_optin!='1')) { return $next($request); } // Otherwise make sure they're enrolled and show them the 2FA code screen if ((Auth::user()->two_factor_secret!='') && (Auth::user()->two_factor_enrolled=='1')) { return redirect()->route('two-factor')->with('info', 'Please enter your two-factor authentication code.'); } return redirect()->route('two-factor-enroll')->with('success', 'Please enroll a device in two-factor authentication.'); } } return $next($request); } }