psg / psr-102
App Standardization
Requires
- php: >=5.3.0
- psg/psr-100: ^0.2.0
- psg/psr-101: ^0.4.0
This package is auto-updated.
Last update: 2025-01-15 06:59:15 UTC
README
This standard has been replaced with https://github.com/PHP-SG/sr-2.
PSR 102 App Standardization
PSR 101, the Middleware App, fails some concerns:
- some "middleware" does not care about either the front or the back, and it should not be forced to care by calling
handle
ornext
- some apps need outerware - logic that runs either after the response has been sent, or at the very start, and that is unconcerned with changing the request and response
This has led to LayeredAppInterface.
Concepts
Types
- Beforeware : outerware for setting of configuration
- Frontware : middleware caring only about the front
- Middleware : regular middleware the wraps the core and other middleware
- Coreware : the core app logic that is wrapped by middleware
- Backware : middleware caring only about the back
- Afterware : outerware for doing things after the resopnse, like cleaning up
ExitResponseInterface
For Frontware to force a bypass, because it does not control the flow by calling next, it must return a special response implementing ExitResponseInterface. It does this through the app factory $app->createExitResponse
, which is just like createResponse
.
Request And Response Flow
The above diagram is an oversimplification. The reality looks more like this:
Here you can see that the response is forwarded to the core from the frontware.
Coreware
In Apps, there is an idea of a core which is usually called the controller. What is special about this core is that, regardless of what middleware is added during the running of the app, the core will always be executed at the core (whereas, where middleware is executed depends on the list of other middleware).
I decided to call this core
instead of control
to make it more generic (it also includes running view code).
I also decided to make this a single callable or {instantiable thing with an __invoke method}. In my implementation, I provide the callable with the parameters ($request, $response, $app). It is, however, expectable that frameworks will want to:
- inject parameters as necessary into the core call
- inject parameters into the __construct if the core is an instantiable As such, the parameters are left up to the framework.
Middleware, like a router, can set the core using $app->core($core)
. The $app->core()
method sets this coreware, and will overwrite anything that exists priorhand as the core.
I decided that the coreware should not be multiple. Coreware is not expected to be generic, it is expected to be specific to the app, so a list is unnecessary.
There is the semblance of a conceptual issue about the has
function. Since outerware is now present, and there is front and back specific middleware, what does has
refer to?
Extension
I imagine frameworks will want to extend the LayeredApp with FIG PSR-11 and FIG PSR-14. I may add such an interface to this repo later.