summaryrefslogtreecommitdiffstats
path: root/src/Router/Middleware/ErrorHandler.php
diff options
context:
space:
mode:
authorArnold Daniels <arnold@jasny.net>2016-10-20 19:50:05 +0200
committerGitHub <noreply@github.com>2016-10-20 19:50:05 +0200
commit17e7a0af39e479c554d5dc4a064678d9fde71fc0 (patch)
treeab4a4f26492ac3c0262f801a8f90251eff1cfdf2 /src/Router/Middleware/ErrorHandler.php
parentbbd7fe10d23e838271c94dbca59dd986cb7c8620 (diff)
parentaf57d0a805b1abdf1bd529902d820a586b3b7455 (diff)
downloadrouter-origin/router-cleanup.zip
router-origin/router-cleanup.tar.gz
router-origin/router-cleanup.tar.bz2
Merge pull request #10 from Minstel/middleware-errorsorigin/router-cleanup
Middleware errors
Diffstat (limited to 'src/Router/Middleware/ErrorHandler.php')
-rw-r--r--src/Router/Middleware/ErrorHandler.php54
1 files changed, 54 insertions, 0 deletions
diff --git a/src/Router/Middleware/ErrorHandler.php b/src/Router/Middleware/ErrorHandler.php
new file mode 100644
index 0000000..789c455
--- /dev/null
+++ b/src/Router/Middleware/ErrorHandler.php
@@ -0,0 +1,54 @@
+<?php
+
+namespace Jasny\Router\Middleware;
+
+use Psr\Http\Message\ServerRequestInterface;
+use Psr\Http\Message\ResponseInterface;
+
+/**
+ * Handle error in following middlewares/app actions
+ */
+class ErrorHandler
+{
+ /**
+ * Run middleware action
+ *
+ * @param ServerRequestInterface $request
+ * @param ResponseInterface $response
+ * @param callback $next
+ * @return ResponseInterface
+ */
+ public function __invoke(ServerRequestInterface $request, ResponseInterface $response, $next = null)
+ {
+ if ($next && !is_callable($next)) {
+ throw new \InvalidArgumentException("'next' should be a callback");
+ }
+
+ $error = false;
+
+ try {
+ $response = $next ? call_user_func($next, $request, $response) : $response;
+ } catch(\Throwable $e) {
+ $error = true;
+ } catch(\Exception $e) { #This block can be removed when migrating to PHP7, because Throwable represents both Exception and Error
+ $error = true;
+ }
+
+ return $error ? $this->handleError($response) : $response;
+ }
+
+ /**
+ * Handle caught error
+ *
+ * @param ResponseInterface $response
+ * @return ResponseInterface
+ */
+ protected function handleError($response)
+ {
+ $body = $response->getBody();
+ $body->rewind();
+ $body->write('Unexpected error');
+
+ return $response->withStatus(500, 'Internal Server Error')->withBody($body);
+ }
+}