Struct h3::server::Builder

source ·
pub struct Builder { /* private fields */ }
Expand description

Builder of HTTP/3 server connections.

Use this struct to create a new Connection. Settings for the Connection can be provided here.

§Example

fn doc<C,B>(conn: C)
where
C: h3::quic::Connection<B>,
B: bytes::Buf,
{
    let mut server_builder = h3::server::builder();
    // Set the maximum header size
    server_builder.max_field_section_size(1000);
    // do not send grease types
    server_builder.send_grease(false);
    // Build the Connection
    let mut h3_conn = server_builder.build(conn);
}

Implementations§

source§

impl Builder

source

pub fn max_field_section_size(&mut self, value: u64) -> &mut Self

Set the maximum header size this client is willing to accept

See header size constraints section of the specification for details.

source

pub fn send_grease(&mut self, value: bool) -> &mut Self

Send grease values to the Client. See setting, frame and stream for more information.

source

pub fn enable_webtransport(&mut self, value: bool) -> &mut Self

Indicates to the peer that WebTransport is supported.

See: establishing a webtransport session

Server: Supporting for webtransport also requires setting enable_connect enable_datagram and max_webtransport_sessions.

source

pub fn enable_connect(&mut self, value: bool) -> &mut Self

Enables the CONNECT protocol

source

pub fn max_webtransport_sessions(&mut self, value: u64) -> &mut Self

Limits the maximum number of WebTransport sessions

source

pub fn enable_datagram(&mut self, value: bool) -> &mut Self

Indicates that the client or server supports HTTP/3 datagrams

See: https://www.rfc-editor.org/rfc/rfc9297#section-2.1.1

source§

impl Builder

source

pub async fn build<C, B>(&self, conn: C) -> Result<Connection<C, B>, Error>
where C: Connection<B>, B: Buf,

Build an HTTP/3 connection from a QUIC connection

This method creates a Connection instance with the settings in the Builder.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more