1 unstable release

0.1.0 Sep 29, 2023

#7 in #rate-limiter

Download history 407/week @ 2024-01-01 543/week @ 2024-01-08 700/week @ 2024-01-15 950/week @ 2024-01-22 1018/week @ 2024-01-29 941/week @ 2024-02-05 466/week @ 2024-02-12 436/week @ 2024-02-19 381/week @ 2024-02-26 280/week @ 2024-03-04 187/week @ 2024-03-11 259/week @ 2024-03-18 236/week @ 2024-03-25 182/week @ 2024-04-01 127/week @ 2024-04-08 103/week @ 2024-04-15

657 downloads per month

MIT license

5KB

reqwest-leaky-bucket

leaky-bucket rate-limit middleware implementation for reqwest-middleware based on reqwest-ratelimit.

Crates.io Docs.rs

Usage

use async_trait::async_trait;
use reqwest_leaky_bucket::leaky_bucket::RateLimiter;
use reqwest_middleware::{ClientBuilder, ClientWithMiddleware};

async fn run() {
    let limiter = RateLimiter::builder().max(10).initial(0).refill(5).build();
    let client = ClientBuilder::new(reqwest::Client::new())
        .with(reqwest_leaky_bucket::rate_limit_all(limiter))
        .build();
    client.get("https://crates.io").send().await.unwrap();
}

lib.rs:

Middleware to rate-limit requests built on reqwest_middleware, reqwest_ratelimit and leaky_bucket.

Provides a reqwest_ratelimit::RateLimiter adapter for leaky_bucket::RateLimiter.

Example

use async_trait::async_trait;
use reqwest_leaky_bucket::leaky_bucket::RateLimiter;
use reqwest_middleware::{ClientBuilder, ClientWithMiddleware};

async fn run() {
    let limiter = RateLimiter::builder().max(10).initial(0).refill(5).build();

    let client = ClientBuilder::new(reqwest::Client::new())
        .with(reqwest_leaky_bucket::rate_limit_all(limiter))
        .build();

    client.get("https://crates.io").send().await.unwrap();
}

Dependencies

~7–21MB
~305K SLoC