Completed
Pull Request — master (#47)
by
unknown
11:14
created

AuthorisedApiTokenAdmin   A

Complexity

Total Complexity 8

Size/Duplication

Total Lines 45
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 8
c 1
b 0
f 0
lcom 1
cbo 3
dl 0
loc 45
rs 10

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A handle() 0 12 3
A isValidToken() 0 14 3
A parseToken() 0 4 1
1
<?php
2
3
namespace Modules\User\Http\Middleware;
4
5
use Illuminate\Http\Request;
6
use Illuminate\Http\Response;
7
use Modules\User\Repositories\UserTokenRepository;
8
9
class AuthorisedApiTokenAdmin
10
{
11
    /**
12
     * @var UserTokenRepository
13
     */
14
    private $userToken;
15
16
    public function __construct(UserTokenRepository $userToken)
17
    {
18
        $this->userToken = $userToken;
19
    }
20
21
    public function handle(Request $request, \Closure $next)
22
    {
23
        if ($request->header('Authorization') === null) {
24
            return new Response('Forbidden', 403);
25
        }
26
27
        if ($this->isValidToken($request->header('Authorization')) === false) {
28
            return new Response('Forbidden', 403);
29
        }
30
31
        return $next($request);
32
    }
33
34
    private function isValidToken($token)
35
    {
36
        $found = $this->userToken->findByAttributes(['access_token' => $this->parseToken($token)]);
37
38
        if ($found === null) {
39
            return false;
40
        }
41
42
        if ($found->user->hasRoleName('admin') === false) {
43
            return false;
44
        }
45
46
        return true;
47
    }
48
49
    private function parseToken($token)
50
    {
51
        return str_replace('Bearer ', '', $token);
52
    }
53
}
54