Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
| Total | |
80.95% |
17 / 21 |
|
50.00% |
1 / 2 |
CRAP | |
0.00% |
0 / 1 |
| RequestSizeLimitMiddleware | |
80.95% |
17 / 21 |
|
50.00% |
1 / 2 |
5.17 | |
0.00% |
0 / 1 |
| __construct | |
100.00% |
3 / 3 |
|
100.00% |
1 / 1 |
1 | |||
| process | |
77.78% |
14 / 18 |
|
0.00% |
0 / 1 |
4.18 | |||
| 1 | <?php |
| 2 | |
| 3 | declare(strict_types=1); |
| 4 | |
| 5 | namespace BO\Zmscitizenapi\Middleware; |
| 6 | |
| 7 | use BO\Zmscitizenapi\Utils\ErrorMessages; |
| 8 | use BO\Zmscitizenapi\Services\Core\LoggerService; |
| 9 | use Psr\Http\Message\ResponseInterface; |
| 10 | use Psr\Http\Message\ServerRequestInterface; |
| 11 | use Psr\Http\Server\MiddlewareInterface; |
| 12 | use Psr\Http\Server\RequestHandlerInterface; |
| 13 | |
| 14 | class RequestSizeLimitMiddleware implements MiddlewareInterface |
| 15 | { |
| 16 | private const ERROR_TOO_LARGE = 'requestEntityTooLarge'; |
| 17 | private int $maxSize; |
| 18 | private LoggerService $logger; |
| 19 | public function __construct(LoggerService $logger) |
| 20 | { |
| 21 | $this->logger = $logger; |
| 22 | $config = \App::getRequestLimits(); |
| 23 | $this->maxSize = $config['maxSize']; |
| 24 | } |
| 25 | |
| 26 | public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface |
| 27 | { |
| 28 | try { |
| 29 | $contentLength = $request->getHeaderLine('Content-Length'); |
| 30 | if ($contentLength === '') { |
| 31 | return $handler->handle($request); |
| 32 | } |
| 33 | $contentLength = (int)$contentLength; |
| 34 | if ($contentLength > $this->maxSize) { |
| 35 | $this->logger->logInfo(sprintf('Request too large: %d bytes. URI: %s', $contentLength, $request->getUri())); |
| 36 | $response = \App::$slim->getResponseFactory()->createResponse(); |
| 37 | $language = $request->getAttribute('language'); |
| 38 | $response = $response->withStatus(ErrorMessages::get(self::ERROR_TOO_LARGE, $language)['statusCode']) |
| 39 | ->withHeader('Content-Type', 'application/json'); |
| 40 | $response->getBody()->write(json_encode([ |
| 41 | 'errors' => [ErrorMessages::get(self::ERROR_TOO_LARGE, $language)] |
| 42 | ])); |
| 43 | return $response; |
| 44 | } |
| 45 | |
| 46 | return $handler->handle($request); |
| 47 | } catch (\Throwable $e) { |
| 48 | $this->logger->logError($e, $request); |
| 49 | throw $e; |
| 50 | } |
| 51 | } |
| 52 | } |