-
Notifications
You must be signed in to change notification settings - Fork 17.8k
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
net/http: Add Error Callbacks #21548
Comments
@theory consider this: practically there's big enough chance that API would be running behind some kind of load balancer that may send error replies on its own in some scenarios (including malformed client requests). This would violate your assumption about getting replies that only have json payload in their bodies. |
That's often true, @artyom, but not an assumption I'd always want to make. In order to ensure the integrity of the interface I provide, I'd like to have some ability to determine output formats for errors from http itself, regardless of what the operational deployment ultimately looks like. Helps me avoid QA questions, too. |
This one is a potential duplicate of #10123. |
Thanks @artyom, I think you're right. |
#10123 is closed, so should we close this one as well? Or with more experience does this seem like a real problem that net/http ought to address? |
I don't think it's a dup of #10123. Bypassing the handler altogether is a different thing. |
I believe this is a dup of #18997 (via #18095). Please reopen if you disagree. #18997 is a long thread. The tl;dr is here: |
Sorry, reopening, it's not a dup. You don't just want to log, you want to return a custom response. I would not consider it a dup of #10123 either, because #10123 was about overriding http.Error, while this is about returning a custom response for internal errors that user code currently has no control over. I don't know how to fix this cleanly. The quick hack is to add a field |
Not beautiful, but the simplest solution is to add a method one can override something like:
Then check to see if the Handler implements it. Pretty similar to Error(), I guess. |
I have a similar use-case where the stdlib server will usually tell the client that it made a mistake without the handler ever getting a chance to interact with the request. In our case there are two aspects to this:
This is probably somewhat closer to #10123, but still different: I'm looking to respond to errors which are never exposed to a handler compared to being able to replace existing default handlers (e.g. 404). I'm happy to open a different issue if you think this does not fit this issue. The suggestion from @theory is already pretty close, but I'd prefer an approach closer to the existing ServeHTTP function: type ErrorHandler interface {
ServeError(w http.ResponseWriter, r *http.Request, err error)
}
type HttpError interface {
error
StatusCode() int
} The The handler would also be called for some of the cases where currently |
@maxmoehl Looks nice. Is there a way to know what the response code was intended to be? |
Right, it would probably be a good idea to expose that as well, so maybe the interface should be extended to include the encountered error, I've adjusted my original comment (I wanted to do that from the get go but somehow forgot it 😄). That error could also carry the status code which is "proposed" by the stdlib. |
I've written a little REST server on net/http that's supposed to only ever return JSON contents. At least, that's what the parts I wrote do. However, there are certain errors that net/http encounters before my code is ever called. In those situations, I have no access to any code to determine what the content type and message should be for a given error. For example, take this stupid simple implementation:
If I submit a request with borked headers (this one has a wayward newline in the
Authorization
header), myServeHTTP()
method is never called, presumably because there's an error when parsing the request to create the Request object:This makes complete sense to me, but if I'm creating an API with a contract to only ever return JSON, I'd like to have some way to plug into this error response and set the content-type and the body. I think the same challenge exists for
Not Found
errors. Perhaps there could be special handlers to configure these situations, similar to how Gorilla mux provides an assignableNotFoundHandler
field in its Router object?I'm not sure exactly what a generalized interface would look like for such error handlers (methods on Handler protocol?), but some way to hook in and get some control over net/http-initiated error responses would be very useful for guaranteeing the content-type contract of a web API.
The text was updated successfully, but these errors were encountered: