From 330ddf1de1ca2841469d30d24143902e5ff06365 Mon Sep 17 00:00:00 2001 From: dswij Date: Mon, 1 Apr 2024 22:46:22 +0800 Subject: [PATCH] feat(client): add `max_pending_accept_reset_streams` HTTP2 option (#3617) --- src/client/conn/http2.rs | 11 +++++++++++ src/proto/h2/client.rs | 5 +++++ 2 files changed, 16 insertions(+) diff --git a/src/client/conn/http2.rs b/src/client/conn/http2.rs index 823dd87d91..87f4b0e8af 100644 --- a/src/client/conn/http2.rs +++ b/src/client/conn/http2.rs @@ -403,6 +403,17 @@ where self } + /// Configures the maximum number of pending reset streams allowed before a GOAWAY will be sent. + /// + /// This will default to the default value set by the [`h2` crate](https://crates.io/crates/h2). + /// As of v0.4.0, it is 20. + /// + /// See for more information. + pub fn max_pending_accept_reset_streams(&mut self, max: impl Into>) -> &mut Self { + self.h2_builder.max_pending_accept_reset_streams = max.into(); + self + } + /// Constructs a connection with the configured options and IO. /// See [`client::conn`](crate::client::conn) for more. /// diff --git a/src/proto/h2/client.rs b/src/proto/h2/client.rs index 7bc62de57a..59e0f45c23 100644 --- a/src/proto/h2/client.rs +++ b/src/proto/h2/client.rs @@ -73,6 +73,7 @@ pub(crate) struct Config { pub(crate) keep_alive_while_idle: bool, pub(crate) max_concurrent_reset_streams: Option, pub(crate) max_send_buffer_size: usize, + pub(crate) max_pending_accept_reset_streams: Option, } impl Default for Config { @@ -88,6 +89,7 @@ impl Default for Config { keep_alive_while_idle: false, max_concurrent_reset_streams: None, max_send_buffer_size: DEFAULT_MAX_SEND_BUF_SIZE, + max_pending_accept_reset_streams: None, } } } @@ -104,6 +106,9 @@ fn new_builder(config: &Config) -> Builder { if let Some(max) = config.max_concurrent_reset_streams { builder.max_concurrent_reset_streams(max); } + if let Some(max) = config.max_pending_accept_reset_streams { + builder.max_pending_accept_reset_streams(max); + } builder }