Test Failed
Push — dev5 ( 2be149...544eb5 )
by Ron
15:57
created

CheckPasswordExpire::handle()   A

Complexity

Conditions 6
Paths 4

Size

Total Lines 18
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 6
CRAP Score 7.3329

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 6
eloc 8
c 1
b 0
f 0
nc 4
nop 2
dl 0
loc 18
ccs 6
cts 9
cp 0.6667
crap 7.3329
rs 9.2222
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 560
    public function handle($request, Closure $next)
21
    {
22 560
        if(Auth::check() && !(Route::current()->getName() === 'changePassword' || Route::current()->getName() === 'logout'))
23
        {
24
            //  Verify that the users password has not expired
25 502
            if(Auth::user()->password_expires !== null)
26
            {
27 502
                $passExp = new Carbon((Auth::user()->password_expires));
28
                if(Carbon::now() > $passExp )
29 502
                {
30
                    Log::notice('User ID-'.Auth::user()->user_id.' is being forced to change their password.');
31
                    $request->session()->flash('change_password', 'change_password');
32
                    return redirect()->route('changePassword');
33
                }
34
            }
35
        }
36 502
37
        return $next($request);
38
    }
39
}
40