Skip to main content

H3ErrorCode

Enum H3ErrorCode 

Source
#[non_exhaustive]
pub enum H3ErrorCode {
Show 25 variants NoError = 256, GeneralProtocolError = 257, InternalError = 258, StreamCreationError = 259, ClosedCriticalStream = 260, FrameUnexpected = 261, FrameError = 262, ExcessiveLoad = 263, IdError = 264, SettingsError = 265, MissingSettings = 266, RequestRejected = 267, RequestCancelled = 268, RequestIncomplete = 269, MessageError = 270, ConnectError = 271, VersionFallback = 272, WebTransportBufferedStreamRejected = 966_049_156, WebTransportSessionGone = 386_759_528, WebTransportFlowControlError = 73_221_255, WebTransportAlpnError = 135_771_101, WebTransportRequirementsNotMet = 556_535_112, QpackDecompressionFailed = 512, QpackEncoderStreamError = 513, QpackDecoderStreamError = 514,
}
Expand description

H3 error codes (RFC 9114).

Used when closing connections or resetting streams. Unknown error codes decode as NoError.

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

NoError = 256

No error. Used when closing without an error to signal.

§

GeneralProtocolError = 257

Peer violated protocol requirements.

§

InternalError = 258

An internal error in the HTTP stack.

§

StreamCreationError = 259

Peer created a stream that will not be accepted.

§

ClosedCriticalStream = 260

A required stream was closed or reset.

§

FrameUnexpected = 261

A frame was not permitted in the current state or stream.

§

FrameError = 262

A frame fails layout requirements or has an invalid size.

§

ExcessiveLoad = 263

Peer is generating excessive load.

§

IdError = 264

A stream ID or push ID was used incorrectly.

§

SettingsError = 265

Error in the payload of a SETTINGS frame.

§

MissingSettings = 266

No SETTINGS frame at the beginning of the control stream.

§

RequestRejected = 267

Server rejected a request without application processing.

§

RequestCancelled = 268

Request or response (including pushed) is cancelled.

§

RequestIncomplete = 269

Client stream terminated without a fully formed request.

§

MessageError = 270

HTTP message was malformed.

§

ConnectError = 271

TCP connection for CONNECT was reset or abnormally closed.

§

VersionFallback = 272

Requested operation cannot be served over HTTP/3.

§

WebTransportBufferedStreamRejected = 966_049_156

WebTransport data stream rejected due to lack of associated session.

§

WebTransportSessionGone = 386_759_528

WebTransport data stream or session closed because the associated session is gone.

§

WebTransportFlowControlError = 73_221_255

WebTransport session flow control error.

§

WebTransportAlpnError = 135_771_101

WebTransport application protocol negotiation failed.

§

WebTransportRequirementsNotMet = 556_535_112

Required WebTransport settings or transport parameters not met.

§

QpackDecompressionFailed = 512

The decoder failed to interpret a header block.

§

QpackEncoderStreamError = 513

The decoder failed to interpret an encoder stream instruction.

§

QpackDecoderStreamError = 514

The encoder failed to interpret a decoder stream instruction.

Implementations§

Source§

impl H3ErrorCode

Source

pub fn reason(&self) -> Cow<'static, str>

A “reason phrase” suitable for inclusion in a CONNECTION_CLOSE frame.

Source

pub fn is_connection_error(&self) -> bool

Returns true if this error code represents a connection-level error that requires closing the entire QUIC connection (via CONNECTION_CLOSE).

Returns false for stream-level errors such as Self::MessageError or Self::RequestIncomplete, which should reset the individual stream rather than tear down the whole connection.

Trait Implementations§

Source§

impl Clone for H3ErrorCode

Source§

fn clone(&self) -> H3ErrorCode

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Copy for H3ErrorCode

Source§

impl Debug for H3ErrorCode

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for H3ErrorCode

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Eq for H3ErrorCode

Source§

impl Error for H3ErrorCode

1.30.0 · Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<H3ErrorCode> for H3Error

Source§

fn from(source: H3ErrorCode) -> Self

Converts to this type from the input type.
Source§

impl From<H3ErrorCode> for u64

Source§

fn from(code: H3ErrorCode) -> u64

Encodes the error code. NoError emits a random GREASE value (0x1f * N + 0x21) to exercise peer handling of unknown codes.

Source§

impl From<u64> for H3ErrorCode

Source§

fn from(value: u64) -> Self

Unknown error codes decode as NoError.

Source§

impl PartialEq for H3ErrorCode

Source§

fn eq(&self, other: &H3ErrorCode) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for H3ErrorCode

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

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

Source§

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>,

Source§

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.