diff options
author | Alex Auvolat <alex@adnab.me> | 2022-01-25 17:01:39 +0100 |
---|---|---|
committer | Alex Auvolat <alex@adnab.me> | 2022-01-25 17:01:39 +0100 |
commit | b1ac01f53ec110438e8be8ab7716e9d7b6ebb7fe (patch) | |
tree | 5867683287e04bd69e93ad21ad1f432c9794a63d /src/reverse_proxy.rs | |
parent | ea050c7045764f69a6dd25a2b0c75186dddfc50e (diff) | |
download | tricot-docker-34.tar.gz tricot-docker-34.zip |
Try to fix duplicate Host header issuedocker-34
- disable http2 to backend connections even when using tls
- forbid hyper from adding a host header
Diffstat (limited to 'src/reverse_proxy.rs')
-rw-r--r-- | src/reverse_proxy.rs | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/src/reverse_proxy.rs b/src/reverse_proxy.rs index 6ea15a0..c6e0bac 100644 --- a/src/reverse_proxy.rs +++ b/src/reverse_proxy.rs @@ -22,7 +22,7 @@ pub const PROXY_TIMEOUT: Duration = Duration::from_secs(60); const HOP_HEADERS: &[HeaderName] = &[ header::CONNECTION, - //header::KEEP_ALIVE, + // header::KEEP_ALIVE, // not found in http::header header::PROXY_AUTHENTICATE, header::PROXY_AUTHORIZATION, header::TE, @@ -69,7 +69,8 @@ fn create_proxied_request<B>( ) -> Result<Request<B>> { let mut builder = Request::builder() .method(request.method()) - .uri(forward_uri(forward_url, &request)?); + .uri(forward_uri(forward_url, &request)?) + .version(hyper::Version::HTTP_11); *builder.headers_mut().unwrap() = remove_hop_headers(request.headers()); @@ -133,7 +134,7 @@ pub async fn call( let mut connector = HttpConnector::new(); connector.set_connect_timeout(Some(PROXY_TIMEOUT)); - let client: Client<_, hyper::Body> = Client::builder().build(connector); + let client: Client<_, hyper::Body> = Client::builder().set_host(false).build(connector); let response = client.request(proxied_request).await?; @@ -161,7 +162,7 @@ pub async fn call_https( http_connector.set_connect_timeout(Some(PROXY_TIMEOUT)); let connector = HttpsConnectorFixedDnsname::new(tls_config, "dummy", http_connector); - let client: Client<_, hyper::Body> = Client::builder().build(connector); + let client: Client<_, hyper::Body> = Client::builder().set_host(false).build(connector); let response = client.request(proxied_request).await?; trace!("Inner response (HTTPS): {:?}", response); |