Sometimes, it becomes to recycle code to run on multiple routes. Angel allows for this in the form of middleware. Middleware are frequently used as authorization filters, or to serialize database data for use in subsequent routes. Middleware in Angel can be any route handler, whether a function or arbitrary data. You can also throw exceptions in middleware.
Denying Requests via Middleware
A middleware should return either true or false. If false is returned, no further routes will be executed. If true is returned, route evaluation will continue. (more on request handler return values here).
In practice, you will only need to write a return statement when you are returning true.
As you can imagine, this is perfect for authorization filters.
You can call a router's chain method, or assign middleware in the middleware parameter of a route method.
// All ways ultimately accomplish the same thing.
// Keep it readable!
// Cleanest. Use when it doesn't create visual clutter of its own.
// Another readable use of the `.chain()` method.
// Do something here...
// Use when more than one middleware is involved, or when
// using an anonymous function as a handler (or middleware that spans
// multiple lines)
// The `middleware: ` parameter is used internally by `package:angel_route`.
Though this might at first seem redundant, there are actually reasons for all three existing.
By convention, though, follow these readability rules when building Angel servers:
Routes with no middleware should not use chain, app.chain, or `middleware. Self-explanatory.
Routes with one middleware and one handler should use app.chain([...]) when:
The construction of all the middleware does not take more than one line.
In all other cases, use the chain meta-handler.
Avoid using middleware: ... directly, as it is used internally package:route.
To add a handler that handles every request, call app.fallback. This is merely shorthand for calling app.all('*', <handler>). (more info on request lifecycle here).
app.fallback((req, res)async=> res.close());
For more complicated middleware, you can also create a class.
Canonically, when using a class as a request handler, it should provide a handleRequest(RequestContext, ResponseContext) method. This pattern is seen throughout many Angel plugins, such as VirtualDirectory or Proxy.
The reason for this is that a name like handleRequest makes it very clear to anyone reading the code what it is supposed to do. This is the same rationale behind controllers providing a configureServer method.