Lease

Struct Lease 

Source
pub struct Lease {
    pub time_to_live: u32,
    pub number_of_requests: u32,
    pub metadata: BytesMut,
    /* private fields */
}
Expand description

LEASE Frame (0x02)

Lease frames MAY be sent by the client-side or server-side Responders and inform the Requester that it may send Requests for a period of time and how many it may send during that duration. See Lease Semantics for more information.

The last received LEASE frame overrides all previous LEASE frame values.

Lease frames MUST always use Stream ID 0 as they pertain to the Connection.

§Frame Contents

 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                         Stream ID = 0                         |
+-----------+-+-+---------------+-------------------------------+
|Frame Type |0|M|     Flags     |
+-----------+-+-+---------------+-------------------------------+
|0|                       Time-To-Live                          |
+---------------------------------------------------------------+
|0|                     Number of Requests                      |
+---------------------------------------------------------------+
                            Metadata

§Notes

  • A Responder implementation MAY stop all further requests by sending a Lease with a value of 0 for Number of Requests or Time-To-Live.

  • When a Lease expires due to time, the value of the Number of Requests that a Requester may make is implicitly 0.

  • This frame only supports Metadata, so the Metadata Length header MUST NOT be included, even if the FrameFlags::METADATA flag is set true.

Fields§

§time_to_live: u32

Time-To-Live (TTL)

Unsigned 31-bit integer of Time (in milliseconds) for validity of Lease from time of reception. Value MUST be > 0.

§number_of_requests: u32

Number of Requests

Unsigned 31-bit integer of Number of Requests that may be sent until next Lease. Value MUST be > 0.

§metadata: BytesMut

Lease metadata

Implementations§

Source§

impl Lease

Source

pub fn set_metadata(&mut self, metadata: BytesMut)

Sets the value of Lease.metadata

Source

pub const fn builder() -> LeaseBuilder

Creates a builder to builder a frame of this type.

Trait Implementations§

Source§

impl Clone for Lease

Source§

fn clone(&self) -> Lease

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Lease

Source§

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

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

impl Decoder for Lease

Source§

type Error = Error

The type of error that can occur if decoding fails.
Source§

fn decode(__buf: &mut BytesMut) -> Result<Self, Self::Error>

Decodes a value from the given buffer. Read more
Source§

fn has_enough_bytes(_buf: &BytesMut) -> bool

Returns true if the given buffer can be decoded. Read more
Source§

impl Encoder for Lease

Source§

type Error = Error

The type of error that can occur if encoding fails.
Source§

fn encode(input: &Self, __buf: &mut BytesMut) -> Result<(), Self::Error>

Encodes the given input into the output buffer. Read more
Source§

fn size_of(input: &Self) -> usize

Returns the number of bytes required to encode the given input. Read more
Source§

impl FrameVariant for Lease

Source§

const FLAGS_MASK: FrameFlags

Mask that flags of a variant must be in.
Source§

fn flags(&self) -> FrameFlags

Gets the flags of the variant.
Source§

const REQUIRED_FLAGS: FrameFlags = _

Flags that must be set for a variant.
Source§

impl From<Lease> for Frame

Source§

fn from(value: Lease) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl Freeze for Lease

§

impl RefUnwindSafe for Lease

§

impl Send for Lease

§

impl Sync for Lease

§

impl Unpin for Lease

§

impl UnwindSafe for Lease

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<T> EncoderExt for T
where T: Encoder,

Source§

fn encode_to(&self, buf: &mut BytesMut) -> Result<(), Self::Error>

Encodes self into buf. Read more
Source§

fn size(&self) -> usize

Returns the number of bytes required to encode self.
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, 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.