Completed
Push — master ( 77f56b...bad6ef )
by ARCANEDEV
04:03
created

CheckAdministrators::failedAuthorization()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
cc 1
eloc 3
c 0
b 0
f 0
nc 1
nop 0
dl 0
loc 6
ccs 0
cts 6
cp 0
crap 2
rs 9.4285
1
<?php namespace Arcanesoft\Core\Http\Middleware;
2
3
use Arcanedev\Support\Http\Middleware;
4
use Closure;
5
use Illuminate\Auth\Access\AuthorizationException;
6
use Illuminate\Http\Request;
7
8
/**
9
 * Class     AdminMiddleware
10
 *
11
 * @package  Arcanesoft\Foundation\Http\Middleware
12
 * @author   ARCANEDEV <[email protected]>
13
 */
14
class CheckAdministrators extends Middleware
15
{
16
    /* -----------------------------------------------------------------
17
     |  Main Methods
18
     | -----------------------------------------------------------------
19
     */
20
21
    /**
22
     * Run the request filter.
23
     *
24
     * @param  \Illuminate\Http\Request  $request
25
     * @param  \Closure                  $next
26
     *
27
     * @return mixed
28
     *
29
     * @throws \Illuminate\Auth\Access\AuthorizationException
30
     */
31
    public function handle(Request $request, Closure $next)
32
    {
33
        if ( ! $this->isAllowed())
34
            $this->failedAuthorization();
35
36
        return $next($request);
37
    }
38
39
    /* -----------------------------------------------------------------
40
     |  Other Methods
41
     | -----------------------------------------------------------------
42
     */
43
44
    /**
45
     * Check if the user is allowed.
46
     *
47
     * @return bool
48
     */
49
    protected function isAllowed()
50
    {
51
        /** @var  \Arcanesoft\Contracts\Auth\Models\User  $user */
52
        if (is_null($user = auth()->user()))
53
            return false;
54
55
        return $user->isAdmin() || $user->isModerator();
56
    }
57
58
    /**
59
     * Handle a failed authorization attempt.
60
     *
61
     * @throws \Illuminate\Auth\Access\AuthorizationException
62
     */
63
    protected function failedAuthorization()
64
    {
65
        throw new AuthorizationException(
66
            '[Unauthorized] You are not allowed to perform this action.', 403
67
        );
68
    }
69
}
70