A middleware stack with 3 phases:
- Prepare is where you adapt the request;
- Respond is where you modify the response generated by the prepare phase;
- Close is where you output the response and close the current request (ie. closing a session, sending an e-mail...);
Laasti\Stack has 1 dependency: symfony/http-foundation. I chose it because it handles requests and responses in a straightforward fashion. I am waiting for PSR7 to mature and will eventually remove the dependency on HttpFoundation in favour of the PSR7 standard.
It also provides an integration with League\Container.
composer require laasti/stack
Without League\Container:
$stack = new Laasti\Stack\Stack;
//You must at least have one PrepareableMiddleware that returns a Response
$stack->push(new MyPrepareableMiddleware);
//Ouputs the response automatically
$stack->execute(Request::createFromGlobals());
With League\Container:
$container = new League\Container\Container;
$resolver = new Laasti\Stack\ContainerResolver($container);
$stack = new Laasti\Stack\Stack($resolver);
$container->add('MyPrepareableMiddleware');
//You must at least have one PrepareableMiddleware that returns a Response
$stack->push('MyPrepareableMiddleware');
//Ouputs the response automatically
$stack->execute(Request::createFromGlobals());
If you encounter problems with priority, make sure that your middlewares define just one of the middleware types. Also make sure your middlewares do as little as possible so that you can fine tune the priority more easily.
- Fork it!
- Create your feature branch:
git checkout -b my-new-feature
- Commit your changes:
git commit -am 'Add some feature'
- Push to the branch:
git push origin my-new-feature
- Submit a pull request :D
See CHANGELOG.md for more information.
Author: Sonia Marquette (@nebulousGirl)
Released under the MIT License. See LICENSE file.