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 | } |