-
Notifications
You must be signed in to change notification settings - Fork 264
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
No WAI Response composers work to send HTTP 103 Early Hints #970
Comments
The idea of early hints was proposed by a friend of mine and it was standardized by another friend. @thomasjm Could you implement a prototype so that we can discuss how this feature should be provided? |
Sure, I can try. Let me note a few possible problems/breaking changes I foresee:
I started sketching out a solution here. This has an API that works for the I'm not totally sure why this happens. Could it be the case that once you finish reading the full body of the request, and then do a connSendAll on the connection, it causes the connection to be closed right away? I could use some insight from a Warp expert :) My work on |
Never mind, I actually got it to work with Anyway, I've got the tests passing now and opened fpco/http-reverse-proxy#46 ! |
I recently landed snoyberg/http-client#524 (CC @snoyberg) provide HTTP 103 Early Hints support in
http-client
. Now I'm trying to extend this support to http-reverse-proxy, and running into the following problem.The idea of HTTP 103 Early Hints is that an HTTP server can send an initial HTTP status code of 103, along with some headers. This means "the full response is still processing, but in the meantime here are some things you as a client can do to start preparing for it." Primarily this is for browsers to start pre-fetching assets that will be needed. The server can send multiple 103 Early Hints sections before it concludes with the full response.
The key issue here is, we want to start sending status lines and headers to the client, but we don't know what the final status will be yet! It might be 200, or some error might happen during processing and it might be something else.
All of the higher-level
Response
composers in WAI expect aStatus
up front:responseFile
,responseBuilder
,responseLbs
, and evenresponseStream
. (This last one works only for streaming the body, not the status lines/headers.)This leaves only responseRaw. I've tried to use this to implement the reverse proxy here, but it doesn't quite work. My attempt actually sends the 103 Early Hints section, but then closes the connection prematurely. I think this is because
responseRaw
is mainly intended for WebSocket upgrades, and has this line in its documentation:This undefined behavior is inconsistent with using
responseRaw
as part of a reverse proxy.I think to fix this, WAI needs a new response composer, maybe a different flavor of
responseRaw
. Note that the currentresponseRaw
also provides a function to read bytes from the client, which we don't need for this application. Presumably a version without this wouldn't have the undefined behavior issue.The text was updated successfully, but these errors were encountered: