Passed
Branch master (c62005)
by ABDULMALIK
02:15
created

RbacMiddleware::getCurrentUserId()   A

Complexity

Conditions 4
Paths 4

Size

Total Lines 23
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 14
c 1
b 0
f 0
dl 0
loc 23
rs 9.7998
cc 4
nc 4
nop 1
1
<?php
2
3
namespace Potievdev\SlimRbac\Component;
4
5
use Doctrine\ORM\Query\QueryException;
6
use Potievdev\SlimRbac\Exception\InvalidArgumentException;
7
use Potievdev\SlimRbac\Structure\RbacManagerOptions;
8
use Psr\Http\Message\ServerRequestInterface;
9
use Psr\Http\Message\ResponseInterface;
10
11
/**
12
 * Checking Access Middleware
13
 * Class RbacMiddleware
14
 * @package Potievdev\SlimRbac\Component
15
 */
16
class RbacMiddleware extends BaseComponent
17
{
18
    public const PERMISSION_DENIED_CODE = 403;
19
    public const PERMISSION_DENIED_MESSAGE = 'Permission denied';
20
21
    /**
22
     * Check access.
23
     *
24
     * @param  ServerRequestInterface $request PSR7 request
25
     * @param  ResponseInterface $response PSR7 response
26
     * @param  callable $next Next middleware
27
     *
28
     * @return ResponseInterface
29
     * @throws QueryException
30
     * @throws InvalidArgumentException
31
     */
32
    public function __invoke(
33
        ServerRequestInterface $request,
34
        ResponseInterface $response,
35
        callable $next
36
    ): ResponseInterface {
37
        $userId = $this->getCurrentUserId($request);
38
        $permissionName = $request->getUri()->getPath();
39
40
        if ($this->checkAccess($userId, $permissionName)) {
41
            $response = $next($request, $response);
42
        } else {
43
            $response = $response->withStatus(self::PERMISSION_DENIED_CODE, self::PERMISSION_DENIED_MESSAGE);
44
        }
45
46
        return $response;
47
    }
48
49
    private function getCurrentUserId(ServerRequestInterface $request): int
50
    {
51
        $userIdFieldName = $this->rbacManagerOptions->getUserIdFieldName();
52
        $storageType = $this->rbacManagerOptions->getUserIdStorageType();
53
54
        /** @var integer $userId */
55
        switch ($storageType) {
56
57
            case RbacManagerOptions::ATTRIBUTE_STORAGE_TYPE:
58
                $userId = intval($request->getAttribute($userIdFieldName));
59
                break;
60
61
            case RbacManagerOptions::HEADER_STORAGE_TYPE:
62
                $userId = intval($request->getHeaderLine($userIdFieldName));
63
                break;
64
65
            case RbacManagerOptions::COOKIE_STORAGE_TYPE:
66
                $params = $request->getCookieParams();
67
                $userId = intval($params[$userIdFieldName]);
68
                break;
69
        }
70
71
        return $userId;
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable $userId does not seem to be defined for all execution paths leading up to this point.
Loading history...
72
    }
73
}
74