Passed
Pull Request — master (#1074)
by Andrew
02:12 queued 11s
created

DeviceGrantMiddleware   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 27
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 4
Bugs 2 Features 0
Metric Value
eloc 11
dl 0
loc 27
ccs 0
cts 16
cp 0
rs 10
c 4
b 2
f 0
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A process() 0 14 2
A __construct() 0 6 1
1
<?php
2
3
namespace League\OAuth2\Server\Middleware;
4
5
use League\OAuth2\Server\Exception\OAuthServerException;
6
use League\OAuth2\Server\Repositories\DeviceAuthorizationRequestRepository;
7
use Psr\Http\Message\ResponseFactoryInterface;
8
use Psr\Http\Message\ResponseInterface;
9
use Psr\Http\Message\ServerRequestInterface;
10
use Psr\Http\Server\MiddlewareInterface;
11
use Psr\Http\Server\RequestHandlerInterface;
12
13
class DeviceGrantMiddleware implements MiddlewareInterface
14
{
15
    private $deviceAuthorizationRequestRepository;
16
    private $responseFactory;
17
18
    public function __construct(
19
        DeviceAuthorizationRequestRepository $deviceAuthorizationRequestRepository,
20
        ResponseFactoryInterface $responseFactory
21
    ) {
22
        $this->deviceAuthorizationRequestRepository = $deviceAuthorizationRequestRepository;
23
        $this->responseFactory = $responseFactory;
24
    }
25
26
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
27
    {
28
        $queryParameters = $request->getQueryParams();
29
        $deviceCode = $queryParameters['device_code'];
30
31
        // Get the last timestamp this client requested an access code
32
        $lastRequestTimeStamp = $this->deviceAuthorizationRequestRepository->getLast($deviceCode);
33
34
        // If the request is within the last 5 seconds, issue a slowdown notification
35
        if ($lastRequestTimeStamp + 5 > \time()) {
36
            return OAuthServerException::slowDown()->generateHttpResponse($this->responseFactory->createResponse());
37
        }
38
39
        return $handler->handle($request);
40
    }
41
}
42