The package is a PSR-15 middleware dispatcher. Given a set of middleware and a request instance, dispatcher executes it and produces a response instance.
- PHP 8.1 or higher.
The package could be installed with Composer:
composer require yiisoft/middleware-dispatcher
To use a dispatcher, you need to create it first:
use Yiisoft\Middleware\Dispatcher\MiddlewareDispatcher;
use Yiisoft\Middleware\Dispatcher\MiddlewareFactory;
$dispatcher = new MiddlewareDispatcher(
new MiddlewareFactory($diContainer),
$eventDispatcher
);
In the above $diContainer
is an instance of PSR-11 \Psr\Container\ContainerInterface
and $eventDispatcher
is an instance of PSR-14 Psr\EventDispatcher\EventDispatcherInterface
.
After dispatcher instance obtained, it should be fed with some middleware:
$dispatcher = $dispatcher->withMiddlewares([
TeapotAccessChecker::class,
static function (): ResponseInterface {
return new Response(418);
},
]);
In the above we have used a callback. Overall the following options are available:
-
A controller handler action in format
[TestController::class, 'index']
.TestController
instance will be created andindex()
method will be executed. -
A name of PSR-15 middleware class. The middleware instance will be obtained from container.
-
A name of PSR-15 request handler class. The request handler instance will be obtained from container and executed.
-
A name or instance of invokable class. If the name of invokable class is provided, the instance will be obtained from container and executed.
-
A function returning a middleware such as
static function (): MiddlewareInterface { return new TestMiddleware(); }
The middleware returned will be executed.
-
A callback
function(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
. -
An array definition (see syntax) of middleware:
[ 'class' => MyMiddleware::class, '__construct()' => [ 'someVar' => 42, ], ]
For handler action and callable typed parameters are automatically injected using dependency injection container.
Current request and handler could be obtained by type-hinting for ServerRequestInterface
and RequestHandlerInterface
.
After middleware set is defined, you can do the dispatching:
$request = new ServerRequest('GET', '/teapot');
$response = $dispatcher->dispatch($request, $this->getRequestHandler());
Given a request dispatcher executes middleware in the set and produces response. First specified middleware will be
executed first. For each middleware
\Yiisoft\Middleware\Dispatcher\Event\BeforeMiddleware
and \Yiisoft\Middleware\Dispatcher\Event\AfterMiddleware
events are triggered.
Parameters resolver could be customized by providing your own ParametersResolverInterface
implementation:
use \Psr\Http\Message\ServerRequestInterface;
use \Yiisoft\Middleware\Dispatcher\ParametersResolverInterface;
class CoolParametersResolver implements ParametersResolverInterface
{
public function resolve(array $parameters, ServerRequestInterface $request): array
{
$resolvedParameters = [];
foreach ($parameters as $name => $parameter) {
if ($request->getAttribute($name) !== null) {
$resolvedParameters[$name] = $request->getAttribute($name)
}
}
return $resolvedParameters;
}
}
Then it could be used like the following:
use Psr\Container\ContainerInterface;
use Yiisoft\Middleware\Dispatcher\MiddlewareDispatcher;
use Yiisoft\Middleware\Dispatcher\MiddlewareFactory;
use Yiisoft\Middleware\Dispatcher\ParametersResolverInterface;
/**
* @var ContainerInterface $container
* @var ParametersResolverInterface $resolver
* @var EventDispatcherInterface $eventDispatcher
*/
$dispatcher = new MiddlewareDispatcher(new MiddlewareFactory($container, $resolver), $eventDispatcher);
To combine several parameters' resolvers use CompositeParametersResolver
:
use Psr\Container\ContainerInterface;
use Psr\EventDispatcher\EventDispatcherInterface;
use Yiisoft\Middleware\Dispatcher\CompositeParametersResolver;
use Yiisoft\Middleware\Dispatcher\MiddlewareDispatcher;
use Yiisoft\Middleware\Dispatcher\MiddlewareFactory;
use Yiisoft\Middleware\Dispatcher\ParametersResolverInterface;
/**
* @var ContainerInterface $container
* @var ParametersResolverInterface $resolver1
* @var ParametersResolverInterface $resolver2
* @var EventDispatcherInterface $eventDispatcher
*/
$dispatcher = new MiddlewareDispatcher(
new MiddlewareFactory($container, new CompositeParametersResolver($resolver1, $resolver2)),
$eventDispatcher,
);
If you need help or have a question, the Yii Forum is a good place for that. You may also check out other Yii Community Resources.
The Yii Middleware Dispatcher is free software. It is released under the terms of the BSD License.
Please see LICENSE
for more information.
Maintained by Yii Software.