diff options
author | Arnold Daniels <arnold@jasny.net> | 2016-11-29 17:22:02 +0100 |
---|---|---|
committer | Arnold Daniels <arnold@jasny.net> | 2016-11-29 17:23:06 +0100 |
commit | 327c2d22068c155cf4e1ca4767d51e55990b119e (patch) | |
tree | 754cf36d2b71c255b38abb6bd2caf3749a19b02e /src/Router | |
parent | 4431ae588f05da88b88ec4b2ba7f752568a7a020 (diff) | |
download | router-origin/determine-route-middleware.zip router-origin/determine-route-middleware.tar.gz router-origin/determine-route-middleware.tar.bz2 |
Added determine route middlewareorigin/determine-route-middleware
This middleware can determine the route at forehand, so it can be used by other middleware
Diffstat (limited to 'src/Router')
-rw-r--r-- | src/Router/Middleware/DetermineRoute.php | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/Router/Middleware/DetermineRoute.php b/src/Router/Middleware/DetermineRoute.php new file mode 100644 index 0000000..fdb0878 --- /dev/null +++ b/src/Router/Middleware/DetermineRoute.php @@ -0,0 +1,61 @@ +<?php + +namespace Jasny\Router\Middleware; + +use Jasny\Router\Routes; +use Psr\Http\Message\ServerRequestInterface; +use Psr\Http\Message\ResponseInterface; + +/** + * Determine the route at forehand, so it can be used by subsequent middleware + */ +class DetermineRoute +{ + /** + * Routes + * @var Routes + */ + protected $routes = null; + + + /** + * Class constructor + * + * @param Routes $routes + */ + public function __construct(Routes $routes) + { + $this->routes = $routes; + } + + /** + * Get routes + * + * @return Routes + */ + public function getRoutes() + { + return $this->routes; + } + + + /** + * Run middleware action + * + * @param ServerRequestInterface $request + * @param ResponseInterface $response + * @param callable $next + * @return ResponseInterface + */ + public function __invoke(ServerRequestInterface $request, ResponseInterface $response, $next) + { + if (!is_callable($next)) { + throw new \InvalidArgumentException("next should be callable"); + } + + $route = $this->routes->getRoute($request); + $requestWithRoute = $request->withAttribute('route', $route); + + return $next($requestWithRoute, $response); + } +} |