laasti / stack
From request to response. A middleware stack with 3 phases: prepare, respond and close
Requires
- php: >=5.4.0
- symfony/http-foundation: ~2.6
Requires (Dev)
- league/container: ~1.3
Suggests
- laasti/route: Provides routing middlewares using league/route
- league/container: Integration provided using ContainerResolver
This package is auto-updated.
Last update: 2024-10-20 23:28:25 UTC
README
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.
Installation
composer require laasti/stack
Usage
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.
Contributing
- 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
History
See CHANGELOG.md for more information.
Credits
Author: Sonia Marquette (@nebulousGirl)
License
Released under the MIT License. See LICENSE file.