-
-
Notifications
You must be signed in to change notification settings - Fork 92
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add handling for unset request types in endpoint #137
Conversation
Please elaborate. There already exists |
So, at the moment, I see it as a matter of taste. But if you can give me a compelling argument, I might reconsider "my taste" :-) |
oh, it's just for ease of use, i needed a way to set all unused handlers to a 404 handler and setting all the other fields to my handler didn't occur to me for some reason only after making this 😭 but yea, its just so you can easily set a function to catch all unset handlers so you don't forget one or something. I guess it would be more useful if there were no nop and it would force you to handle all requests so that you don't have hidden behavior, for me at first I was expecting the main listener to catch this instead of the endpoint and I did not understand why it was a valid request but I didn't get any output, if this makes any sense. |
Yes, it makes total sense! You make a convincing consistency-argument here! My suggestion:
WDYT? Maybe we should even rename |
Sounds good. I'll get to changing it right away. |
added the requested changes, went for |
Thank you, your implementation is great! And sorry it took so long for replying. I had some changes in mind for a while now and eventually am getting to implementing them. One consequence is that I am getting rid of the endpoint settings containing handler function pointers. Instead, I treat "Endpoints" more like a contract / interface: you need to define the get/post/delete/... functions orelse it won't fulfill the contract (checked at comptime). That is more explicit and less magic and less indirect - less room for confusion and hence less coding-around-confusabilities. |
🥲 Oh, should i close the pr then? I'm guessing this is no longer needed? |
Yeah, I am moving away from providing callbacks via settings, to using them straight from the Endpoint struct. Maybe there is a case for providing way to easily set handlers to I value your contribution and it has certainly brought more of my awareness to this stuff - and I eventually decided to rework the whole Endpoint concept 😄 |
Ok. Looking forward to see the new system? Any idea when it's gonna be finished? |
Oh, it's currently on master. Just merged the PR; just need to write more about it, to explain it / the changes, and release it. The new //!
//! An ErrorEndpoint
//!
const std = @import("std");
const zap = @import("zap");
/// A simple endpoint listening on the /error route that causes an error on GET
/// requests, which gets logged to the response (=browser) by default
pub const ErrorEndpoint = @This();
path: []const u8 = "/error",
error_strategy: zap.Endpoint.ErrorStrategy = .log_to_response,
pub fn get(_: *ErrorEndpoint, _: zap.Request) !void {
return error.@"Oh-no!";
}
// unused:
pub fn post(_: *ErrorEndpoint, _: zap.Request) !void {}
pub fn put(_: *ErrorEndpoint, _: zap.Request) !void {}
pub fn delete(_: *ErrorEndpoint, _: zap.Request) !void {}
pub fn patch(_: *ErrorEndpoint, _: zap.Request) !void {}
pub fn options(_: *ErrorEndpoint, _: zap.Request) !void {}
|
No description provided.