stack / builder
Builder for stack middleware based on HttpKernelInterface.
Installs: 41 348 432
Dependents: 51
Suggesters: 3
Security: 0
Stars: 295
Watchers: 13
Forks: 28
Open Issues: 1
Requires
- php: >=7.2.0
- symfony/http-foundation: ~2.1|~3.0|~4.0|~5.0
- symfony/http-kernel: ~2.1|~3.0|~4.0|~5.0
Requires (Dev)
- phpunit/phpunit: ~8.0
- symfony/routing: ^5.0
This package is not auto-updated.
Last update: 2024-08-09 13:33:01 UTC
README
Builder for stack middlewares based on HttpKernelInterface.
Stack/Builder is a small library that helps you construct a nested HttpKernelInterface decorator tree. It models it as a stack of middlewares.
Example
If you want to decorate a silex app with session and cache middlewares, you'll have to do something like this:
use Symfony\Component\HttpKernel\HttpCache\Store; $app = new Silex\Application(); $app->get('/', function () { return 'Hello World!'; }); $app = new Stack\Session( new Symfony\Component\HttpKernel\HttpCache\HttpCache( $app, new Store(__DIR__.'/cache') ) );
This can get quite annoying indeed. Stack/Builder simplifies that:
$stack = (new Stack\Builder()) ->push('Stack\Session') ->push('Symfony\Component\HttpKernel\HttpCache\HttpCache', new Store(__DIR__.'/cache')); $app = $stack->resolve($app);
As you can see, by arranging the layers as a stack, they become a lot easier to work with.
In the front controller, you need to serve the request:
use Symfony\Component\HttpFoundation\Request; $request = Request::createFromGlobals(); $response = $app->handle($request)->send(); $app->terminate($request, $response);
Stack/Builder also supports pushing a callable
on to the stack, for situations
where instantiating middlewares might be more complicated. The callable
should
accept a HttpKernelInterface
as the first argument and should also return a
HttpKernelInterface
. The example above could be rewritten as:
$stack = (new Stack\Builder()) ->push('Stack\Session') ->push(function ($app) { $cache = new HttpCache($app, new Store(__DIR__.'/cache')); return $cache; }) ;