http-cache-ureq

Crates.iohttp-cache-ureq
lib.rshttp-cache-ureq
version1.0.0-alpha.1
created_at2025-08-25 03:15:31.297945+00
updated_at2025-08-25 03:15:31.297945+00
descriptionhttp-cache middleware implementation for ureq
homepagehttps://http-cache.rs
repositoryhttps://github.com/06chaynes/http-cache
max_upload_size
id1809029
size159,329
Christian Haynes (06chaynes)

documentation

README

http-cache-ureq

CI Crates.io Docs.rs Codecov Crates.io

A caching middleware that follows HTTP caching rules, thanks to http-cache-semantics. By default, it uses cacache as the backend cache manager. Provides a simple caching wrapper around ureq.

Minimum Supported Rust Version (MSRV)

1.82.0

Install

With cargo add installed :

cargo add http-cache-ureq

Example

use http_cache_ureq::{CACacheManager, CachedAgent};

#[smol_macros::main]
async fn main() -> Result<(), Box<dyn std::error::Error + Send + Sync>> {
    let client = CachedAgent::builder()
        .cache_manager(CACacheManager::default())
        .build()?;
        
    let response = client
        .get("https://developer.mozilla.org/en-US/docs/Web/HTTP/Caching")
        .call()
        .await?;
        
    println!("Status: {}", response.status());
    Ok(())
}

Basic Usage

The CachedAgent wraps ureq's functionality while providing transparent HTTP caching:

use http_cache_ureq::{CACacheManager, CachedAgent};

// Create a cached agent with default settings
let client = CachedAgent::builder()
    .cache_manager(CACacheManager::default())
    .build()?;

// Use it just like a regular ureq agent
let response = client.get("https://httpbin.org/json").call().await?;

Features

The following features are available. By default manager-cacache is enabled.

  • manager-cacache (default): enable cacache, a high-performance disk cache, backend manager.
  • manager-moka (disabled): enable moka, a high-performance in-memory cache, backend manager.
  • json (disabled): enable JSON support via ureq's json feature.
  • rate-limiting (disabled): enable rate limiting functionality.

Documentation

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Commit count: 449

cargo fmt