Skip to main content

Headers

Struct Headers 

Source
pub struct Headers {
    pub limit: usize,
    pub remaining: usize,
    pub reset: ResetTime,
    pub window: Option<Duration>,
    pub vendor: Vendor,
}
Expand description

HTTP rate limits as parsed from header values

Fields§

§limit: usize

The maximum number of requests allowed in the time window

§remaining: usize

The number of requests remaining in the time window

§reset: ResetTime

The time at which the rate limit will be reset

§window: Option<Duration>

The time window until the rate limit is lifted. It is optional, because it might not be given, in which case it needs to be inferred from the environment

§vendor: Vendor

Predicted vendor based on rate limit header

Implementations§

Source§

impl Headers

Source

pub fn new<T: Into<CaseSensitiveHeaderMap>>(headers: T) -> Result<Self, Error>

Extracts rate limits from HTTP headers.

Different vendors (e.g. GitHub, Vimeo, Twitter) use different header names. This function attempts to identify the vendor based on the presence of known headers.

There are many websites abusing or reusing rate limit headers with their own definition of what the values mean. This library tries to be pessimistic and only attempts to parse the rate limit headers if it trusts the website to follow one of the supported variants.

Some vendors might use the same header names but different value formats. In this case, the library will try to parse the headers using the different variants until one succeeds.

§Errors

Returns an error if the headers do not contain a known rate limit format, or if the header values cannot be parsed.

Source

pub const fn limit(&self) -> usize

Get the number of requests allowed in the time window

Source

pub const fn remaining(&self) -> usize

Get the number of requests remaining in the time window

Source

pub const fn reset(&self) -> ResetTime

Get the time at which the rate limit will be reset

Trait Implementations§

Source§

impl Clone for Headers

Source§

fn clone(&self) -> Headers

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 Headers

Source§

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

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

impl FromStr for Headers

Source§

type Err = Error

The associated error which can be returned from parsing.
Source§

fn from_str(map: &str) -> Result<Self, Error>

Parses a string s to return a value of this type. Read more
Source§

impl PartialEq for Headers

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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 Copy for Headers

Source§

impl StructuralPartialEq for Headers

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<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> Same for T

Source§

type Output = T

Should always be Self
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.