Passed
Pull Request — master (#140)
by Zhukov
02:12
created

AuthMiddleware   A

Complexity

Total Complexity 9

Size/Duplication

Total Lines 54
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 23
c 1
b 0
f 0
dl 0
loc 54
ccs 22
cts 22
cp 1
rs 10
wmc 9

5 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A setRequestName() 0 3 1
A isOptional() 0 10 3
A process() 0 14 3
A setOptional() 0 3 1
1
<?php
2
namespace Yiisoft\Yii\Web\Auth;
3
4
use Psr\Http\Message\ResponseFactoryInterface;
5
use Psr\Http\Message\ResponseInterface;
6
use Psr\Http\Message\ServerRequestInterface;
7
use Psr\Http\Server\MiddlewareInterface;
8
use Psr\Http\Server\RequestHandlerInterface;
9
use Yiisoft\Strings\StringHelper;
10
11
final class AuthMiddleware implements MiddlewareInterface
12
{
13
    private const REQUEST_NAME = 'auth_user';
14
15
    private $requestName = self::REQUEST_NAME;
16
    private $responseFactory;
17
    private $authenticator;
18
    private $optional = [];
19
20 3
    public function __construct(ResponseFactoryInterface $responseFactory, AuthInterface $authenticator)
21
    {
22 3
        $this->responseFactory = $responseFactory;
23 3
        $this->authenticator = $authenticator;
24
    }
25
26 3
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
27
    {
28 3
        $identity = $this->authenticator->authenticate($request);
29 3
        $request = $request->withAttribute($this->requestName, $identity);
30
31 3
        if ($identity === null && !$this->isOptional($request)) {
32 1
            $response = $this->responseFactory->createResponse(401);
33 1
            $response = $this->authenticator->challenge($response);
34 1
            $response->getBody()->write('Your request was made with invalid credentials.');
35
36 1
            return $response;
37
        }
38
39 2
        return $handler->handle($request);
40
    }
41
42 1
    public function setRequestName(string $name): void
43
    {
44 1
        $this->requestName = $name;
45
    }
46
47 1
    public function setOptional(array $optional): void
48
    {
49 1
        $this->optional = $optional;
50
    }
51
52
    /**
53
     * Checks, whether authentication is optional for the given action.
54
     */
55 2
    private function isOptional(ServerRequestInterface $request): bool
56
    {
57 2
        $path = $request->getUri()->getPath();
58 2
        foreach ($this->optional as $pattern) {
59 1
            if (StringHelper::matchWildcard($pattern, $path)) {
60 1
                return true;
61
            }
62
        }
63
64 1
        return false;
65
    }
66
}
67