mirror of https://github.com/adamdruppe/arsd.git
better 1xx code handling
This commit is contained in:
parent
2a4567e795
commit
48d75992b7
47
http2.d
47
http2.d
|
@ -1106,6 +1106,8 @@ class HttpRequest {
|
||||||
/// The headers are being sent now
|
/// The headers are being sent now
|
||||||
sendingHeaders,
|
sendingHeaders,
|
||||||
|
|
||||||
|
// FIXME: allow Expect: 100-continue and separate the body send
|
||||||
|
|
||||||
/// The body is being sent now
|
/// The body is being sent now
|
||||||
sendingBody,
|
sendingBody,
|
||||||
|
|
||||||
|
@ -1264,9 +1266,10 @@ class HttpRequest {
|
||||||
|
|
||||||
headers ~= "\r\n";
|
headers ~= "\r\n";
|
||||||
|
|
||||||
|
// FIXME: separate this for 100 continue
|
||||||
sendBuffer = cast(ubyte[]) headers ~ requestParameters.bodyData;
|
sendBuffer = cast(ubyte[]) headers ~ requestParameters.bodyData;
|
||||||
|
|
||||||
// import std.stdio; writeln("******* ", sendBuffer);
|
// import std.stdio; writeln("******* ", cast(string) sendBuffer);
|
||||||
|
|
||||||
responseData = HttpResponse.init;
|
responseData = HttpResponse.init;
|
||||||
responseData.requestParameters = requestParameters;
|
responseData.requestParameters = requestParameters;
|
||||||
|
@ -2180,30 +2183,34 @@ class HttpRequest {
|
||||||
headerReadingState.atStartOfLine = false;
|
headerReadingState.atStartOfLine = false;
|
||||||
if(data[position] == '\r' || data[position] == '\n') {
|
if(data[position] == '\r' || data[position] == '\n') {
|
||||||
// done with headers
|
// done with headers
|
||||||
if(data[position] == '\r' && (position + 1) < data.length && data[position + 1] == '\n')
|
|
||||||
position++;
|
|
||||||
// 101 Switching Protocols
|
|
||||||
// 102 Processing
|
|
||||||
// FIXME: skip 103 Early Hints too
|
|
||||||
// i should just skip all the 100 things unrecognized.
|
|
||||||
if(responseData.headers.length && responseData.headers[0].indexOf(" 100 ") != -1) {
|
|
||||||
// HTTP/1.1 100 Continue
|
|
||||||
// here we just discard the continue message and carry on; it is just informational anyway
|
|
||||||
// it arguably should be smarter though
|
|
||||||
responseData.headers = null;
|
|
||||||
headerReadingState.atStartOfLine = true;
|
|
||||||
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
if(this.requestParameters.method == HttpVerb.HEAD)
|
|
||||||
state = State.complete;
|
|
||||||
else
|
|
||||||
state = State.readingBody;
|
|
||||||
}
|
|
||||||
position++; // skip the newline
|
position++; // skip the newline
|
||||||
|
|
||||||
if(responseData.headers.length)
|
if(responseData.headers.length)
|
||||||
parseLastHeader();
|
parseLastHeader();
|
||||||
|
|
||||||
|
if(responseData.code >= 100 && responseData.code < 200) {
|
||||||
|
// "100 Continue" - we should continue uploading request data at this point
|
||||||
|
// "101 Switching Protocols" - websocket, not expected here...
|
||||||
|
// "102 Processing" - server still working, keep the connection alive
|
||||||
|
// "103 Early Hints" - can have useful Link headers etc
|
||||||
|
//
|
||||||
|
// and other unrecognized ones can just safely be skipped
|
||||||
|
|
||||||
|
// FIXME: the headers shouldn't actually be reset; 103 Early Hints
|
||||||
|
// can give useful headers we want to keep
|
||||||
|
|
||||||
|
responseData.headers = null;
|
||||||
|
headerReadingState.atStartOfLine = true;
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.requestParameters.method == HttpVerb.HEAD)
|
||||||
|
state = State.complete;
|
||||||
|
else
|
||||||
|
state = State.readingBody;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
} else if(data[position] == ' ' || data[position] == '\t') {
|
} else if(data[position] == ' ' || data[position] == '\t') {
|
||||||
// line continuation, ignore all whitespace and collapse it into a space
|
// line continuation, ignore all whitespace and collapse it into a space
|
||||||
|
|
Loading…
Reference in New Issue