Skip to content

Commit

Permalink
fix: [torrust#613] add timeout for time waiting for the first HTTP tr…
Browse files Browse the repository at this point in the history
…acker

request

Adds a timeout to the HTTP tracker for the time the server waits for the
first request from the client after openning a new HTTP connection.

It also adds a tower middleware for timeouts in requests.
  • Loading branch information
josecelano authored and da2ce7 committed Jun 20, 2024
1 parent c52d72b commit 1f9012f
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 5 deletions.
9 changes: 6 additions & 3 deletions src/servers/http/launcher.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,8 @@ use super::check::check_builder;
use super::handle::Handle;
use super::v1::routes::router;
use crate::core::Tracker;
use crate::servers::{registar, service};
use crate::servers::custom_axum_server::TimeoutAcceptor;
use crate::servers::{custom_axum_server, registar, service};

#[derive(Constructor, Clone, Debug, Display)]
#[display(fmt = "intended_address: {addr}, with tracker, and {}", "self.have_tls()")]
Expand Down Expand Up @@ -54,14 +55,16 @@ impl service::Launcher<Handle> for Launcher {
let make_service = router(self.tracker, &addr).into_make_service_with_connect_info::<std::net::SocketAddr>();

match self.tls.clone() {
Some(tls) => axum_server::from_tcp_rustls(listener, tls)
Some(tls) => custom_axum_server::from_tcp_rustls_with_timeouts(listener, tls)
.handle(handle.axum_handle.clone())
.acceptor(TimeoutAcceptor)
.serve(make_service)
.map_err(|e| service::Error::UnableToServe { err: e.into() })
.boxed(),

None => axum_server::from_tcp(listener)
None => custom_axum_server::from_tcp_with_timeouts(listener)
.handle(handle.axum_handle.clone())
.acceptor(TimeoutAcceptor)
.serve(make_service)
.map_err(|e| service::Error::UnableToServe { err: e.into() })
.boxed(),
Expand Down
16 changes: 14 additions & 2 deletions src/servers/http/v1/routes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,15 @@ use std::net::SocketAddr;
use std::sync::Arc;
use std::time::Duration;

use axum::error_handling::HandleErrorLayer;
use axum::http::HeaderName;
use axum::response::Response;
use axum::routing::get;
use axum::Router;
use axum::{BoxError, Router};
use axum_client_ip::SecureClientIpSource;
use hyper::Request;
use hyper::{Request, StatusCode};
use tower::timeout::TimeoutLayer;
use tower::ServiceBuilder;
use tower_http::compression::CompressionLayer;
use tower_http::propagate_header::PropagateHeaderLayer;
use tower_http::request_id::{MakeRequestUuid, SetRequestIdLayer};
Expand All @@ -18,6 +21,8 @@ use tracing::{Level, Span};
use super::handlers::{announce, health_check, scrape};
use crate::core::Tracker;

const TIMEOUT: Duration = Duration::from_secs(5);

/// It adds the routes to the router.
///
/// > **NOTICE**: it's added a layer to get the client IP from the connection
Expand Down Expand Up @@ -69,4 +74,11 @@ pub fn router(tracker: Arc<Tracker>, &addr: &SocketAddr) -> Router {
}),
)
.layer(SetRequestIdLayer::x_request_id(MakeRequestUuid))
.layer(
ServiceBuilder::new()
// this middleware goes above `TimeoutLayer` because it will receive
// errors returned by `TimeoutLayer`
.layer(HandleErrorLayer::new(|_: BoxError| async { StatusCode::REQUEST_TIMEOUT }))
.layer(TimeoutLayer::new(TIMEOUT)),
)
}

0 comments on commit 1f9012f

Please sign in to comment.