Completed
Pull Request — master (#140)
by Zhukov
02:07
created

AuthMiddleware::process()   A

Complexity

Conditions 3
Paths 2

Size

Total Lines 14
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 9
CRAP Score 3

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 3
eloc 8
c 1
b 0
f 0
nc 2
nop 2
dl 0
loc 14
ccs 9
cts 9
cp 1
crap 3
rs 10
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