pub struct Builder<E> { /* private fields */ }
Expand description
A configuration builder for HTTP/2 server connections.
Note: The default values of options are not considered stable. They are subject to change at any time.
Implementations§
Source§impl<E> Builder<E>
impl<E> Builder<E>
Sourcepub fn new(exec: E) -> Builder<E>
pub fn new(exec: E) -> Builder<E>
Create a new connection builder.
This starts with the default options, and an executor which is a type
that implements Http2ServerConnExec
trait.
Sourcepub fn max_pending_accept_reset_streams(
&mut self,
max: impl Into<Option<usize>>,
) -> &mut Builder<E>
pub fn max_pending_accept_reset_streams( &mut self, max: impl Into<Option<usize>>, ) -> &mut Builder<E>
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.
As of v0.4.0, it is 20.
See https://github.com/hyperium/hyper/issues/2877 for more information.
Sourcepub fn max_local_error_reset_streams(
self,
max: impl Into<Option<usize>>,
) -> Builder<E>
pub fn max_local_error_reset_streams( self, max: impl Into<Option<usize>>, ) -> Builder<E>
Configures the maximum number of local reset streams allowed before a GOAWAY will be sent.
If not set, hyper will use a default, currently of 1024.
If None
is supplied, hyper will not apply any limit.
This is not advised, as it can potentially expose servers to DOS vulnerabilities.
See https://rustsec.org/advisories/RUSTSEC-2024-0003.html for more information.
Sourcepub fn initial_stream_window_size(
&mut self,
sz: impl Into<Option<u32>>,
) -> &mut Builder<E>
pub fn initial_stream_window_size( &mut self, sz: impl Into<Option<u32>>, ) -> &mut Builder<E>
Sets the SETTINGS_INITIAL_WINDOW_SIZE
option for HTTP2
stream-level flow control.
Passing None
will do nothing.
If not set, hyper will use a default.
Sourcepub fn initial_connection_window_size(
&mut self,
sz: impl Into<Option<u32>>,
) -> &mut Builder<E>
pub fn initial_connection_window_size( &mut self, sz: impl Into<Option<u32>>, ) -> &mut Builder<E>
Sets the max connection-level flow control for HTTP2.
Passing None
will do nothing.
If not set, hyper will use a default.
Sourcepub fn adaptive_window(&mut self, enabled: bool) -> &mut Builder<E>
pub fn adaptive_window(&mut self, enabled: bool) -> &mut Builder<E>
Sets whether to use an adaptive flow control.
Enabling this will override the limits set in
initial_stream_window_size
and
initial_connection_window_size
.
Sourcepub fn max_frame_size(&mut self, sz: impl Into<Option<u32>>) -> &mut Builder<E>
pub fn max_frame_size(&mut self, sz: impl Into<Option<u32>>) -> &mut Builder<E>
Sets the maximum frame size to use for HTTP2.
Passing None
will do nothing.
If not set, hyper will use a default.
Sourcepub fn max_concurrent_streams(
&mut self,
max: impl Into<Option<u32>>,
) -> &mut Builder<E>
pub fn max_concurrent_streams( &mut self, max: impl Into<Option<u32>>, ) -> &mut Builder<E>
Sets the SETTINGS_MAX_CONCURRENT_STREAMS
option for HTTP2
connections.
Default is 200, but not part of the stability of hyper. It could change in a future release. You are encouraged to set your own limit.
Passing None
will remove any limit.
Sourcepub fn keep_alive_interval(
&mut self,
interval: impl Into<Option<Duration>>,
) -> &mut Builder<E>
pub fn keep_alive_interval( &mut self, interval: impl Into<Option<Duration>>, ) -> &mut Builder<E>
Sets an interval for HTTP2 Ping frames should be sent to keep a connection alive.
Pass None
to disable HTTP2 keep-alive.
Default is currently disabled.
Sourcepub fn keep_alive_timeout(&mut self, timeout: Duration) -> &mut Builder<E>
pub fn keep_alive_timeout(&mut self, timeout: Duration) -> &mut Builder<E>
Sets a timeout for receiving an acknowledgement of the keep-alive ping.
If the ping is not acknowledged within the timeout, the connection will
be closed. Does nothing if keep_alive_interval
is disabled.
Default is 20 seconds.
Sourcepub fn max_send_buf_size(&mut self, max: usize) -> &mut Builder<E>
pub fn max_send_buf_size(&mut self, max: usize) -> &mut Builder<E>
Set the maximum write buffer size for each HTTP/2 stream.
Default is currently ~400KB, but may change.
§Panics
The value must be no larger than u32::MAX
.
Sourcepub fn enable_connect_protocol(&mut self) -> &mut Builder<E>
pub fn enable_connect_protocol(&mut self) -> &mut Builder<E>
Enables the extended CONNECT protocol.
Sourcepub fn max_header_list_size(&mut self, max: u32) -> &mut Builder<E>
pub fn max_header_list_size(&mut self, max: u32) -> &mut Builder<E>
Sets the max size of received header frames.
Default is currently 16KB, but can change.
Sourcepub fn timer<M>(&mut self, timer: M) -> &mut Builder<E>
pub fn timer<M>(&mut self, timer: M) -> &mut Builder<E>
Set the timer used in background tasks.
Sourcepub fn auto_date_header(&mut self, enabled: bool) -> &mut Builder<E>
pub fn auto_date_header(&mut self, enabled: bool) -> &mut Builder<E>
Set whether the date
header should be included in HTTP responses.
Note that including the date
header is recommended by RFC 7231.
Default is true.
Sourcepub fn serve_connection<S, I, Bd>(
&self,
io: I,
service: S,
) -> Connection<I, S, E> ⓘ
pub fn serve_connection<S, I, Bd>( &self, io: I, service: S, ) -> Connection<I, S, E> ⓘ
Bind a connection together with a Service
.
This returns a Future that must be polled in order for HTTP to be driven on the connection.
Trait Implementations§
Auto Trait Implementations§
impl<E> Freeze for Builder<E>where
E: Freeze,
impl<E> !RefUnwindSafe for Builder<E>
impl<E> Send for Builder<E>where
E: Send,
impl<E> Sync for Builder<E>where
E: Sync,
impl<E> Unpin for Builder<E>where
E: Unpin,
impl<E> !UnwindSafe for Builder<E>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more