Completed
Push — dev5 ( 502bc5...e6b46e )
by Ron
08:18
created

CheckPasswordExpire   A

Complexity

Total Complexity 8

Size/Duplication

Total Lines 33
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 11
c 1
b 0
f 0
dl 0
loc 33
rs 10
wmc 8

1 Method

Rating   Name   Duplication   Size   Complexity  
B handle() 0 24 8
1
<?php
2
3
namespace App\Http\Middleware;
4
5
use Closure;
6
use Carbon\Carbon;
7
use Illuminate\Support\Facades\Log;
8
use Illuminate\Support\Facades\Auth;
9
use Illuminate\Support\Facades\Route;
10
11
class CheckPasswordExpire
12
{
13
    /**
14
     * Handle an incoming request.
15
     *
16
     * @param  \Illuminate\Http\Request  $request
17
     * @param  \Closure  $next
18
     * @return mixed
19
     */
20
    public function handle($request, Closure $next)
21
    {
22
        if(Auth::check() && !(Route::current()->getName() === 'changePassword' || Route::current()->getName() === 'logout'))
23
        {
24
            //  Verify that the users password has not expired
25
            $user = $request->user();
26
27
            if($user->password_expires != null)
28
            {
29
                $passExp = new Carbon(($user->password_expires));
30
31
                if(!empty($passExp) && Carbon::now() > $passExp && !empty(config('users.passExpires')))
32
                {
33
                    Log::notice('User ID-'.Auth::user()->user_id.' is being forced to change their password.');
34
                    $request->session()->flash('change_password', 'change_password');
35
                    return redirect()->route('changePassword');
36
                }
37
            }
38
39
            return $next($request);
40
            
41
        }
42
        
43
        return $next($request);
44
    }
45
}
46