mirror of
https://github.com/zigzap/zap.git
synced 2025-10-20 15:14:08 +00:00
update docs and examples for endpoint middleware
This commit is contained in:
parent
c5325337e1
commit
903716bcf5
2 changed files with 18 additions and 15 deletions
|
@ -123,19 +123,17 @@ const SessionMiddleWare = struct {
|
|||
//
|
||||
// !!!! ENDPOINT !!!
|
||||
//
|
||||
// We define an endpoint as we usually would.
|
||||
// NO ROUTING IS PERFORMED
|
||||
// as we are just going to wrap it in a bunch of Middleware components
|
||||
// and therefore NOT using an endpoint listener that would the routing for us
|
||||
// We define an endpoint as we usually would; however,
|
||||
// NO ROUTING IS PERFORMED BY DEFAULT!
|
||||
//
|
||||
// Hence, the endpoint should check r.path in its on_request to check wether
|
||||
// it is adressed or not.
|
||||
// This can be changed using the EndpointHandlerOptions passed into the
|
||||
// EndpointHandler.init() method.
|
||||
//
|
||||
// N.B. the EndpointHandler checks if the endpoint turned the request into
|
||||
// "finished" state, e.g. by sending anything. If the endpoint didn't finish the
|
||||
// request, the EndpointHandler will pass the request on to the next handler in
|
||||
// the chain if there is one. See also the EndpointHandler's `breakOnFinish`
|
||||
// parameter.
|
||||
// the chain if there is one. See also the EndpointHandlerOptions's
|
||||
// `breakOnFinish` parameter.
|
||||
//
|
||||
const HtmlEndpoint = struct {
|
||||
ep: zap.Endpoint = undefined,
|
||||
|
@ -210,7 +208,7 @@ pub fn main() !void {
|
|||
var htmlHandler = zap.Middleware.EndpointHandler(Handler, Context).init(
|
||||
htmlEndpoint.endpoint(), // the endpoint
|
||||
null, // no other handler (we are the last in the chain)
|
||||
true, // break on finish. See EndpointHandler for this. Not applicable here.
|
||||
.{}, // We can set custom EndpointHandlerOptions here
|
||||
);
|
||||
|
||||
// we wrap it in the session Middleware component
|
||||
|
|
|
@ -51,14 +51,15 @@ pub fn Handler(comptime ContextType: anytype) type {
|
|||
};
|
||||
}
|
||||
|
||||
/// Options used to change the behavior of an `EndpointHandler`
|
||||
pub const EndpointHandlerOptions = struct {
|
||||
/// If `true`, the handler will stop handing requests down the chain if the
|
||||
/// endpoint processed the request.
|
||||
breakOnFinish: bool = true,
|
||||
|
||||
/// If `true`, the handler will only execute against request that match the
|
||||
/// endpoint's path setting.
|
||||
useRoutes: bool = false,
|
||||
/// If `true`, the handler will only execute against requests that match
|
||||
/// the endpoint's `path` setting.
|
||||
checkPath: bool = false,
|
||||
};
|
||||
|
||||
/// A convenience handler for artibrary zap.Endpoint
|
||||
|
@ -71,8 +72,12 @@ pub fn EndpointHandler(comptime HandlerType: anytype, comptime ContextType: anyt
|
|||
const Self = @This();
|
||||
|
||||
/// Create an endpointhandler from an endpoint and pass in the next (other) handler in the chain.
|
||||
/// If `breakOnFinish` is `true`, the handler will stop handing requests down the chain if
|
||||
/// the endpoint processed the request.
|
||||
///
|
||||
/// By default no routing is performed on requests. This behavior can be changed by setting
|
||||
/// `checkPath` in the provided options.
|
||||
///
|
||||
/// If the `breakOnFinish` option is `true`, the handler will stop handing requests down the chain
|
||||
/// if the endpoint processed the request.
|
||||
pub fn init(endpoint: *zap.Endpoint, other: ?*HandlerType, options: EndpointHandlerOptions) Self {
|
||||
return .{
|
||||
.handler = HandlerType.init(onRequest, other),
|
||||
|
@ -94,7 +99,7 @@ pub fn EndpointHandler(comptime HandlerType: anytype, comptime ContextType: anyt
|
|||
pub fn onRequest(handler: *HandlerType, r: zap.Request, context: *ContextType) bool {
|
||||
const self: *Self = @fieldParentPtr("handler", handler);
|
||||
r.setUserContext(context);
|
||||
if (!self.options.useRoutes or
|
||||
if (!self.options.checkPath or
|
||||
std.mem.startsWith(u8, r.path orelse "", self.endpoint.settings.path))
|
||||
{
|
||||
self.endpoint.onRequest(r);
|
||||
|
|
Loading…
Add table
Reference in a new issue