nghttpx: Remove host if :authority is available on HTTP2 downstream request

This commit is contained in:
Tatsuhiro Tsujikawa 2013-12-15 18:09:56 +09:00
parent 3c63936d3a
commit 3c57327274
2 changed files with 17 additions and 8 deletions

View File

@ -160,6 +160,7 @@ namespace {
const char *IGN_HD[] = {
"connection",
"expect",
"host",
"http2-settings",
"keep-alive",
"proxy-connection",

View File

@ -267,11 +267,15 @@ int Http2DownstreamConnection::push_request_headers()
nva.push_back(http2::make_nv_ls
(":authority",
downstream_->get_request_http2_authority()));
} else if(downstream_->get_norm_request_header("host") == end_headers) {
if(LOG_ENABLED(INFO)) {
DCLOG(INFO, this) << "host header field missing";
} else {
auto host = downstream_->get_norm_request_header("host");
if(host == end_headers) {
if(LOG_ENABLED(INFO)) {
DCLOG(INFO, this) << "host header field missing";
}
return -1;
}
return -1;
nva.push_back(http2::make_nv_ls("host", (*host).second));
}
} else {
// The upstream is HTTP/1
@ -318,11 +322,15 @@ int Http2DownstreamConnection::push_request_headers()
authority += util::utos(u.port);
}
nva.push_back(http2::make_nv_ls(":authority", authority));
} else if(downstream_->get_norm_request_header("host") == end_headers) {
if(LOG_ENABLED(INFO)) {
DCLOG(INFO, this) << "host header field missing";
} else {
auto host = downstream_->get_norm_request_header("host");
if(host == end_headers) {
if(LOG_ENABLED(INFO)) {
DCLOG(INFO, this) << "host header field missing";
}
return -1;
}
return -1;
nva.push_back(http2::make_nv_ls("host", (*host).second));
}
}