From 1aced2bef57df5b540353650cae6d50eb6cc08f0 Mon Sep 17 00:00:00 2001 From: Mohammad AlSaleh Date: Mon, 29 Mar 2021 21:13:23 +0300 Subject: [PATCH] Allow setting low speed timeouts via Configurable Expose libcurl's low speed timeout functionality by adding a `low_speed_timeout()` method to `Configurable`. Signed-off-by: Mohammad AlSaleh --- src/config/mod.rs | 10 ++++++++++ src/config/request.rs | 6 ++++++ 2 files changed, 16 insertions(+) diff --git a/src/config/mod.rs b/src/config/mod.rs index 3a05c55b..941dd28f 100644 --- a/src/config/mod.rs +++ b/src/config/mod.rs @@ -89,6 +89,16 @@ pub trait Configurable: request::WithRequestConfig { }) } + /// Specify a maximum amount of time where transfer rate can go below + /// a minimum speed limit. `low_speed` is that limit in bytes/s. + /// + /// If not set, no low speed limits are imposed. + fn low_speed_timeout(self, low_speed: u32, timeout: Duration) -> Self { + self.with_config(move |config| { + config.low_speed_timeout = Some((low_speed, timeout)); + }) + } + /// Configure how the use of HTTP versions should be negotiated with the /// server. /// diff --git a/src/config/request.rs b/src/config/request.rs index 4df4ba77..d29236e3 100644 --- a/src/config/request.rs +++ b/src/config/request.rs @@ -65,6 +65,7 @@ define_request_config! { // Used by curl timeout: Option, connect_timeout: Option, + low_speed_timeout: Option<(u32, Duration)>, version_negotiation: Option, automatic_decompression: Option, authentication: Option, @@ -98,6 +99,11 @@ impl SetOpt for RequestConfig { easy.timeout(timeout)?; } + if let Some((low_speed, timeout)) = self.low_speed_timeout { + easy.low_speed_limit(low_speed)?; + easy.low_speed_time(timeout)?; + } + if let Some(timeout) = self.connect_timeout { easy.connect_timeout(timeout)?; }