Completed
Push — master ( 5c0b6f...5c71f2 )
by Oleg
10:16
created

GenerateTemporaryTokenAction::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 11

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 6
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 11
ccs 6
cts 6
cp 1
rs 9.9
c 0
b 0
f 0
cc 1
nc 1
nop 4
crap 1
1
<?php
2
declare(strict_types=1);
3
4
namespace SlayerBirden\DataFlowServer\Authentication\Controller;
5
6
use Psr\Http\Message\ResponseInterface;
7
use Psr\Http\Message\ServerRequestInterface;
8
use Psr\Http\Server\MiddlewareInterface;
9
use Psr\Http\Server\RequestHandlerInterface;
10
use Psr\Log\LoggerInterface;
11
use SlayerBirden\DataFlowServer\Authentication\Exception\PermissionDeniedException;
12
use SlayerBirden\DataFlowServer\Authentication\TokenManagerInterface;
13
use SlayerBirden\DataFlowServer\Doctrine\Middleware\ResourceMiddlewareInterface;
14
use SlayerBirden\DataFlowServer\Domain\Entities\User;
15
use SlayerBirden\DataFlowServer\Notification\DangerMessage;
16
use SlayerBirden\DataFlowServer\Notification\SuccessMessage;
17
use SlayerBirden\DataFlowServer\Stdlib\Validation\DataValidationResponseFactory;
18
use SlayerBirden\DataFlowServer\Stdlib\Validation\ValidationResponseFactory;
19
use Zend\Diactoros\Response\JsonResponse;
20
use Zend\Hydrator\HydratorInterface;
21
use Zend\InputFilter\InputFilterInterface;
22
23
final class GenerateTemporaryTokenAction implements MiddlewareInterface
24
{
25
    /**
26
     * @var TokenManagerInterface
27
     */
28
    private $tokenManager;
29
    /**
30
     * @var LoggerInterface
31
     */
32
    private $logger;
33
    /**
34
     * @var HydratorInterface
35
     */
36
    private $hydrator;
37
    /**
38
     * @var InputFilterInterface
39
     */
40
    private $inputFilter;
41
42 8
    public function __construct(
43
        InputFilterInterface $inputFilter,
44
        TokenManagerInterface $tokenManager,
45
        LoggerInterface $logger,
46
        HydratorInterface $hydrator
47
    ) {
48 8
        $this->tokenManager = $tokenManager;
49 8
        $this->logger = $logger;
50 8
        $this->hydrator = $hydrator;
51 8
        $this->inputFilter = $inputFilter;
52 8
    }
53
54
    /**
55
     * @inheritdoc
56
     */
57 8
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
58
    {
59 8
        $data = $request->getParsedBody();
60 8
        if (!is_array($data)) {
61
            return (new DataValidationResponseFactory())('token');
62
        }
63 8
        $this->inputFilter->setData($data);
64
65 8
        $user = $request->getAttribute(ResourceMiddlewareInterface::DATA_RESOURCE);
66
67 8
        if ($this->inputFilter->isValid()) {
68 7
            return $this->createToken($user, $data['resources']);
69
        } else {
70 1
            return (new ValidationResponseFactory())('token', $this->inputFilter);
71
        }
72
    }
73
74 7
    private function createToken(User $user, array $resources): ResponseInterface
75
    {
76
        try {
77 7
            $token = $this->tokenManager->getTmpToken($user, $resources);
78 5
            return new JsonResponse([
79 5
                'data' => [
80 5
                    'token' => $this->hydrator->extract($token),
81
                    'validation' => [],
82
                ],
83
                'success' => true,
84 5
                'msg' => new SuccessMessage('Token created'),
85 5
            ], 200);
86 2
        } catch (PermissionDeniedException $exception) {
87 2
            return new JsonResponse([
88 2
                'data' => [
89
                    'token' => null,
90
                    'validation' => [],
91
                ],
92
                'success' => false,
93 2
                'msg' => new DangerMessage($exception->getMessage()),
94 2
            ], 400);
95
        } catch (\Exception $exception) {
96
            $this->logger->error((string)$exception);
97
            return new JsonResponse([
98
                'data' => [
99
                    'token' => null,
100
                    'validation' => [],
101
                ],
102
                'success' => false,
103
                'msg' => new DangerMessage('There was an error while obtaining tmp token.'),
104
            ], 500);
105
        }
106
    }
107
}
108