Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
| Total | |
0.00% |
0 / 7 |
|
0.00% |
0 / 2 |
CRAP | |
0.00% |
0 / 1 |
| RequestLoggingMiddleware | |
0.00% |
0 / 7 |
|
0.00% |
0 / 2 |
12 | |
0.00% |
0 / 1 |
| __construct | |
0.00% |
0 / 1 |
|
0.00% |
0 / 1 |
2 | |||
| process | |
0.00% |
0 / 6 |
|
0.00% |
0 / 1 |
6 | |||
| 1 | <?php |
| 2 | |
| 3 | declare(strict_types=1); |
| 4 | |
| 5 | namespace BO\Zmscitizenapi\Middleware; |
| 6 | |
| 7 | use BO\Zmscitizenapi\Services\Core\LoggerService; |
| 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 | /** |
| 14 | * Middleware for logging HTTP requests and responses |
| 15 | */ |
| 16 | class RequestLoggingMiddleware implements MiddlewareInterface |
| 17 | { |
| 18 | private LoggerService $logger; |
| 19 | /** |
| 20 | * @param LoggerService $logger Service for logging requests and responses |
| 21 | */ |
| 22 | public function __construct(LoggerService $logger) |
| 23 | { |
| 24 | $this->logger = $logger; |
| 25 | } |
| 26 | |
| 27 | /** |
| 28 | * Process an incoming server request and log its details |
| 29 | * |
| 30 | * @param ServerRequestInterface $request The request to process |
| 31 | * @param RequestHandlerInterface $handler The handler to process the request |
| 32 | * @return ResponseInterface The resulting response |
| 33 | * @throws \Throwable If an error occurs during request handling |
| 34 | */ |
| 35 | public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface |
| 36 | { |
| 37 | try { |
| 38 | $response = $handler->handle($request); |
| 39 | $this->logger->logRequest($request, $response); |
| 40 | return $response; |
| 41 | } catch (\Throwable $e) { |
| 42 | $this->logger->logError($e, $request); |
| 43 | throw $e; |
| 44 | } |
| 45 | } |
| 46 | } |