summaryrefslogtreecommitdiffstats
path: root/src/Router/Middleware
diff options
context:
space:
mode:
Diffstat (limited to 'src/Router/Middleware')
-rw-r--r--src/Router/Middleware/ErrorHandler.php54
-rw-r--r--src/Router/Middleware/ErrorPage.php75
2 files changed, 129 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);
+ }
+}
diff --git a/src/Router/Middleware/ErrorPage.php b/src/Router/Middleware/ErrorPage.php
new file mode 100644
index 0000000..7064b1e
--- /dev/null
+++ b/src/Router/Middleware/ErrorPage.php
@@ -0,0 +1,75 @@
+<?php
+
+namespace Jasny\Router\Middleware;
+
+use Jasny\Router;
+use Psr\Http\Message\ServerRequestInterface;
+use Psr\Http\Message\ResponseInterface;
+
+/**
+ * Route to error page on error
+ */
+class ErrorPage
+{
+ /**
+ * Router
+ * @var Router
+ */
+ protected $router = null;
+
+ /**
+ * Class constructor
+ *
+ * @param Router $routes
+ */
+ public function __construct(Router $router)
+ {
+ $this->router = $router;
+ }
+
+ /**
+ * Get router connected to middleware
+ *
+ * @return Router
+ */
+ public function getRouter()
+ {
+ return $this->router;
+ }
+
+ /**
+ * 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");
+ }
+
+ $response = $next ? call_user_func($next, $request, $response) : $response;
+ $status = $response->getStatusCode();
+
+ if (!$this->isErrorStatus($status)) return $response;
+
+ $uri = $request->getUri()->withPath("/$status");
+ $request = $request->withUri($uri, true);
+
+ return $this->getRouter()->run($request, $response);
+ }
+
+ /**
+ * Detect if response has error status code
+ *
+ * @param int $status
+ * @return boolean
+ */
+ protected function isErrorStatus($status)
+ {
+ return $status >= 400 && $status < 600;
+ }
+}