Any middleware requires following 3 members:
##struct context
Storing data for the middleware; can be read from another middleware or handlers
##before_handle
Called before handling the request.
If `res.end()` is called, the operation is halted. (`after_handle` will still be called)
2 signatures:
`#!cpp void before_handle(request& req, response& res, context& ctx)`
if you only need to access this middleware's context.
``` cpp
template
void before_handle(request& req, response& res, context& ctx, AllContext& all_ctx)
```
You can access other middlewares' context by calling `#!cpp all_ctx.template get()`
`#!cpp ctx == all_ctx.template get()`
##after_handle
Called after handling the request.
`#!cpp void after_handle(request& req, response& res, context& ctx)`
``` cpp
template
void after_handle(request& req, response& res, context& ctx, AllContext& all_ctx)
```
This was pulled from `cookie_parser.h`. Further Editing required, possibly use parts of [@ipkn's wiki page](https://github.com/ipkn/crow/wiki/Middleware).