| Conditions | 3 |
| Paths | 2 |
| Total Lines | 39 |
| Code Lines | 25 |
| Lines | 0 |
| Ratio | 0 % |
| Tests | 0 |
| CRAP Score | 12 |
| Changes | 0 | ||
| 1 | <?php |
||
| 16 | public function process(\Psr\Http\Message\ServerRequestInterface $request, \Interop\Http\ServerMiddleware\DelegateInterface $delegate) |
||
| 17 | { |
||
| 18 | try { |
||
| 19 | $response = $delegate->process($request); |
||
| 20 | } catch(\Phrest\Http\Exception $e) { |
||
| 21 | $error = $e->error(); |
||
| 22 | |||
| 23 | $errorEntries = []; |
||
| 24 | foreach($error->errors() as $errorEntry) { |
||
| 25 | /** @var \Phrest\API\ErrorEntry $errorEntry */ |
||
| 26 | $errorEntries[] = [ |
||
| 27 | 'code' => $errorEntry->code(), |
||
| 28 | 'message' => $errorEntry->message(), |
||
| 29 | 'field' => $errorEntry->field(), |
||
| 30 | 'constraint' => $errorEntry->constraint() |
||
| 31 | ]; |
||
| 32 | } |
||
| 33 | |||
| 34 | $response = new \Zend\Diactoros\Response\JsonResponse( |
||
| 35 | [ |
||
| 36 | 'code' => $error->code(), |
||
| 37 | 'message' => $error->message(), |
||
| 38 | 'http' => [ |
||
| 39 | 'code' => $e->getCode(), |
||
| 40 | 'message' => \Phrest\Http\StatusCodes::message($e->getCode()), |
||
| 41 | ], |
||
| 42 | 'errors' => $errorEntries |
||
| 43 | ], |
||
| 44 | $e->getCode() |
||
| 45 | ); |
||
| 46 | |||
| 47 | $this->logger->info('Exception: '.$e->getMessage(), [ |
||
| 48 | 'exception' => get_class($e), |
||
| 49 | 'file' => $e->getFile(), |
||
| 50 | 'line' => $e->getLine(), |
||
| 51 | 'trace' => explode("\n", $e->getTraceAsString()) |
||
| 52 | ]); |
||
| 53 | } |
||
| 54 | return $response; |
||
| 55 | } |
||
| 56 | } |