Authenticate   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 40
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 0
Metric Value
wmc 4
lcom 1
cbo 3
dl 0
loc 40
c 0
b 0
f 0
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A handle() 0 12 3
1
<?php
2
3
/**
4
 * Storgman - Student Organizations Management
5
 * Copyright (C) 2014, Dejan Angelov <[email protected]>
6
 *
7
 * This file is part of Storgman.
8
 *
9
 * Storgman is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU General Public License as published by
11
 * the Free Software Foundation, either version 3 of the License, or
12
 * (at your option) any later version.
13
 *
14
 * Storgman is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU General Public License
20
 * along with Storgman.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 * @package Storgman
23
 * @copyright Copyright (C) 2014, Dejan Angelov <[email protected]>
24
 * @license https://github.com/angelov/storgman/blob/master/LICENSE
25
 * @author Dejan Angelov <[email protected]>
26
 */
27
28
namespace Angelov\Storgman\Members\Authentication\Http\Middleware;
29
30
use Closure;
31
use Illuminate\Contracts\Auth\Guard;
32
use Illuminate\Http\Request;
33
34
class Authenticate
35
{
36
    /**
37
     * The Guard implementation.
38
     *
39
     * @var Guard
40
     */
41
    protected $auth;
42
43
    /**
44
     * Create a new filter instance.
45
     *
46
     * @param  Guard $auth
47
     * @return @void
0 ignored issues
show
Documentation introduced by
The doc-type @void could not be parsed: Unknown type name "@void" at position 0. (view supported doc-types)

This check marks PHPDoc comments that could not be parsed by our parser. To see which comment annotations we can parse, please refer to our documentation on supported doc-types.

Loading history...
48
     */
49
    public function __construct(Guard $auth)
50
    {
51
        $this->auth = $auth;
52
    }
53
54
    /**
55
     * Handle an incoming request.
56
     *
57
     * @param  Request  $request
58
     * @param  \Closure  $next
59
     * @return mixed
60
     */
61
    public function handle(Request $request, Closure $next)
62
    {
63
        if ($this->auth->guest()) {
64
            if ($request->ajax()) {
65
                return response('Unauthorized.', 401);
66
            } else {
67
                return redirect()->guest('auth');
68
            }
69
        }
70
71
        return $next($request);
72
    }
73
}
74