1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- <?php
- namespace App\Http\Middleware;
- use App\Models\AppSession;
- use Closure;
- class ProAuthenticated
- {
- /**
- * Handle an incoming request.
- *
- * @param \Illuminate\Http\Request $request
- * @param \Closure $next
- * @return mixed
- */
- public function handle($request, Closure $next)
- {
- $sessionKey = $request->cookie('sessionKey');
- $appSession = AppSession::where(['session_key' => $sessionKey, 'is_active' => true])->first();
- $authenticated = $sessionKey && $appSession;
- if (!$authenticated) {
- return redirect()->route('login');
- }
- // - is_two_step_sms_auth_completed
- $currentRouteName = $request->route()->getName();
- if (!$appSession->is_two_step_sms_auth_completed) {
- if ($currentRouteName != 'confirm_sms_auth_token') {
- return redirect()->route('confirm_sms_auth_token');
- }
- return $next($request);
- }
- // - is_password_temporary
- if (!$appSession->is_password_temporary) {
- if ($currentRouteName != 'set_password') {
- return redirect()->route('set_password');
- }
- return $next($request);
- }
- // - are_security_questions_set
- if (!$appSession->are_security_questions_set) {
- if ($currentRouteName != 'set_security_questions') {
- return redirect()->route('set_security_questions');
- }
- return $next($request());
- }
- return $next($request);
- }
- }
|