Completed
Push — master ( 99c4e8...3c79d6 )
by Alexander
02:19
created

AuthMiddleware   A

Complexity

Total Complexity 9

Size/Duplication

Total Lines 54
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 23
c 1
b 0
f 0
dl 0
loc 54
ccs 0
cts 34
cp 0
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
    public function __construct(ResponseFactoryInterface $responseFactory, AuthInterface $authenticator)
21
    {
22
        $this->responseFactory = $responseFactory;
23
        $this->authenticator = $authenticator;
24
    }
25
26
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
27
    {
28
        $identity = $this->authenticator->authenticate($request);
29
        $request->withAttribute($this->requestName, $identity);
30
31
        if ($identity === null && !$this->isOptional($request)) {
32
            $response = $this->responseFactory->createResponse(401);
33
            $response = $this->authenticator->challenge($response);
34
            $response->getBody()->write('Your request was made with invalid credentials.');
35
36
            return $response;
37
        }
38
39
        return $handler->handle($request);
40
    }
41
42
    public function setRequestName(string $name): void
43
    {
44
        $this->requestName = $name;
45
    }
46
47
    public function setOptional(array $optional): void
48
    {
49
        $this->optional = $optional;
50
    }
51
52
    /**
53
     * Checks, whether authentication is optional for the given action.
54
     */
55
    private function isOptional(ServerRequestInterface $request): bool
56
    {
57
        $path = $request->getUri()->getPath();
58
        foreach ($this->optional as $pattern) {
59
            if (StringHelper::matchWildcard($pattern, $path)) {
60
                return true;
61
            }
62
        }
63
64
        return false;
65
    }
66
}
67