#[non_exhaustive]pub enum RateLimitKey {
User,
Ip,
Tenant,
UserAction,
Global,
Custom(String),
}Expand description
Rate limit key type for bucketing.
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.
User
Per-user rate limiting.
Ip
Per-IP rate limiting.
Tenant
Per-tenant rate limiting.
UserAction
Per-user-action rate limiting (combines user and action).
Global
Global rate limiting (single bucket for all requests).
Custom(String)
Custom claim-based bucketing. The inner string is the JWT claim name
whose value is used as the bucket discriminator. Backends receive this
variant via build_key and may further customise the resolution logic.
Macro syntax: #[query(rate_limit(requests = 100, per = "1m", key = "custom:claim_name"))]
Implementations§
Source§impl RateLimitKey
impl RateLimitKey
Sourcepub fn as_str(&self) -> &str
pub fn as_str(&self) -> &str
Convert to a string representation.
For Self::Custom this returns "custom" — use Self::custom_name
to retrieve the inner claim name.
Sourcepub fn custom_name(&self) -> Option<&str>
pub fn custom_name(&self) -> Option<&str>
Return the inner claim name for Self::Custom, or None for the
standard variants.
Trait Implementations§
Source§impl Clone for RateLimitKey
impl Clone for RateLimitKey
Source§fn clone(&self) -> RateLimitKey
fn clone(&self) -> RateLimitKey
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for RateLimitKey
impl Debug for RateLimitKey
Source§impl Default for RateLimitKey
impl Default for RateLimitKey
Source§fn default() -> RateLimitKey
fn default() -> RateLimitKey
Returns the “default value” for a type. Read more
Source§impl FromStr for RateLimitKey
impl FromStr for RateLimitKey
Source§impl PartialEq for RateLimitKey
impl PartialEq for RateLimitKey
Source§fn eq(&self, other: &RateLimitKey) -> bool
fn eq(&self, other: &RateLimitKey) -> bool
Tests for
self and other values to be equal, and is used by ==.impl Eq for RateLimitKey
impl StructuralPartialEq for RateLimitKey
Auto Trait Implementations§
impl Freeze for RateLimitKey
impl RefUnwindSafe for RateLimitKey
impl Send for RateLimitKey
impl Sync for RateLimitKey
impl Unpin for RateLimitKey
impl UnsafeUnpin for RateLimitKey
impl UnwindSafe for RateLimitKey
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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>
Converts
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>
Converts
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