pub struct RateLimiter { /* private fields */ }Expand description
Token bucket rate limiter for tool calls.
Each tool can have an independent rate limit. When a tool’s bucket is empty,
acquire() blocks until a token becomes available (backpressure).
Implementations§
Source§impl RateLimiter
impl RateLimiter
Sourcepub async fn set_limit(&self, tool: &str, limit: RateLimit)
pub async fn set_limit(&self, tool: &str, limit: RateLimit)
Configure a rate limit for a specific tool.
max_calls tokens over interval_secs seconds. The refill rate is
max_calls / interval_secs tokens per second.
Sourcepub async fn acquire(&self, tool: &str)
pub async fn acquire(&self, tool: &str)
Wait until a token is available for the given tool, then consume it.
If no rate limit is configured for the tool, returns immediately. This provides backpressure: callers block until capacity is available.
Sourcepub async fn try_acquire(&self, tool: &str) -> bool
pub async fn try_acquire(&self, tool: &str) -> bool
Non-blocking attempt to acquire a token for the given tool.
Returns true if a token was consumed, false if the bucket is empty.
Returns true if no rate limit is configured for the tool.
Trait Implementations§
Auto Trait Implementations§
impl !Freeze for RateLimiter
impl !RefUnwindSafe for RateLimiter
impl Send for RateLimiter
impl Sync for RateLimiter
impl Unpin for RateLimiter
impl UnsafeUnpin for RateLimiter
impl !UnwindSafe for RateLimiter
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> 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