Completed
Push — master ( 3f8955...ef1f27 )
by Lorenzo
09:30
created

HttpsForceMiddleware::isSecureRequest()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 5
rs 10
c 0
b 0
f 0
cc 2
nc 2
nop 1
1
<?php
2
3
namespace Padosoft\Laravel\Https\Middleware;
4
5
use Closure;
6
use Illuminate\Http\Request;
7
8
class HttpsForceMiddleware
9
{
10
    /**
11
     * Handle an incoming request and redirect if not https.
12
     *
13
     * @param  \Illuminate\Http\Request  $request
14
     * @param  \Closure  $next
15
     * @return mixed
16
     */
17
    public function handle(Request $request, Closure $next)
18
    {
19
        if ($this->isSecureRequest($request)) {
20
            return $next($request);
21
        }
22
23
        if (config('laravel-https.always_force_https')) {
24
            return redirect()->secure($request->getRequestUri(), 301);
25
        }
26
27
        if (\App::environment(config('laravel-https.https_if_env_equal'))) {
28
            return redirect()->secure($request->getRequestUri(), 301);
29
        }
30
31
        return $next($request);
32
    }
33
34
    /**
35
     * @param Request $request
36
     * @return mixed
37
     */
38
    public function isSecureRequest(Request $request)
39
    {
40
        $xForwardedProto = strtolower($request->header('X_FORWARDED_PROTO', ''));
41
        return ($request->secure() || $xForwardedProto=='https');
42
    }
43
}
44