AuthorizationPipeline   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 54
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 29
dl 0
loc 54
ccs 34
cts 34
cp 1
rs 10
c 0
b 0
f 0
wmc 5

3 Methods

Rating   Name   Duplication   Size   Complexity  
A withHandler() 0 5 1
A process() 0 35 3
A __construct() 0 6 1
1
<?php declare(strict_types=1);
2
3
namespace jschreuder\MiddleAuth\Basic;
4
5
use jschreuder\MiddleAuth\AuthorizationHandlerInterface;
6
use jschreuder\MiddleAuth\AuthorizationPipelineInterface;
7
use jschreuder\MiddleAuth\AuthorizationRequestInterface;
8
use jschreuder\MiddleAuth\AuthorizationResponseInterface;
9
use jschreuder\MiddleAuth\Util\AuthLoggerInterface;
10
use jschreuder\MiddleAuth\Util\NullAuthLogger;
11
12
final class AuthorizationPipeline implements AuthorizationPipelineInterface
13
{
14
    private AuthLoggerInterface $logger;
15
16 12
    public function __construct(
17
        private \SplQueue $queue,
18
        ?AuthLoggerInterface $logger = null
19
    )
20
    {
21 12
        $this->logger = $logger ?? new NullAuthLogger();
22
    }
23
24 4
    public function withHandler(AuthorizationHandlerInterface $handler): self
25
    {
26 4
        $newQueue = clone $this->queue;
27 4
        $newQueue->enqueue($handler);
28 4
        return new self($newQueue, $this->logger);
29
    }
30
31 10
    public function process(AuthorizationRequestInterface $request): AuthorizationResponseInterface
32
    {
33 10
        if ($this->queue->count() === 0) {
34 3
            $this->logger->warning('Authorization pipeline is empty, no handlers to process');
35 3
            throw new \RuntimeException('Pipeline is empty, no handlers to process.');
36
        }
37
38 7
        $this->logger->debug('Authorization pipeline processing request', [
39 7
            'subject_type' => $request->getSubject()->getType(),
40 7
            'subject_id' => $request->getSubject()->getId(),
41 7
            'resource_type' => $request->getResource()->getType(),
42 7
            'resource_id' => $request->getResource()->getId(),
43 7
            'action' => $request->getAction(),
44 7
        ]);
45
46 7
        $queue = clone $this->queue;
47 7
        $handler = $queue->dequeue();
48
49 7
        $response = $handler->handle($request);
50
51 7
        $this->logger->info(
52 7
            'Authorization decision: ' . ($response->isPermitted() ? 'PERMIT' : 'DENY'),
53 7
            [
54 7
                'subject_type' => $request->getSubject()->getType(),
55 7
                'subject_id' => $request->getSubject()->getId(),
56 7
                'resource_type' => $request->getResource()->getType(),
57 7
                'resource_id' => $request->getResource()->getId(),
58 7
                'action' => $request->getAction(),
59 7
                'permitted' => $response->isPermitted(),
60 7
                'reason' => $response->getReason(),
61 7
                'handler' => $response->getHandler(),
62 7
            ]
63 7
        );
64
65 7
        return $response;
66
    }
67
}
68