10 releases

new 0.1.10 Dec 11, 2024
0.1.8 Oct 28, 2024
0.1.6 Jul 23, 2024
0.1.1 Mar 6, 2024

#137 in HTTP client

Download history 28/week @ 2024-08-21 43/week @ 2024-08-28 53/week @ 2024-09-04 85/week @ 2024-09-11 85/week @ 2024-09-18 104/week @ 2024-09-25 195/week @ 2024-10-02 139/week @ 2024-10-09 497/week @ 2024-10-16 151/week @ 2024-10-23 95/week @ 2024-10-30 96/week @ 2024-11-06 105/week @ 2024-11-13 108/week @ 2024-11-20 97/week @ 2024-11-27 62/week @ 2024-12-04

393 downloads per month

BSD-2-Clause

62KB
846 lines

🛰️ Fibreq (FIBer REQuests)

Fibreq is non-blocking HTTP client designed specifically for the Tarantool ecosystem, leveraging the Tarantool's fiber capabilities. It aims to provide a robust, feature-rich alternative for making HTTP(S) requests directly from Tarantool instances, inspired by the ease of use seen in libraries like reqwest but tailored for Tarantool's unique environment.

✨Features

  • Non-blocking Nature: Utilizes Tarantool's fiber system for efficient, non-blocking I/O operations.
  • Connection Pooling: Enhances performance by reusing connections across multiple requests, minimizing the overhead of establishing new connections.
  • Comprehensive Timeout Controls: Offers detailed timeout configurations for connection establishment, request sending, and response reading to avoid hanging requests.
  • HTTPS Support: Secures your data with TLS support for HTTPS requests, ensuring your connections are encrypted and safe.
  • Flexible Request Building: Simplifies creating complex requests with a convenient builder pattern, supporting various content types, headers, and body content.
  • Error Handling: Provides clear and actionable errors, making debugging and error resolution straightforward.

📦 Installation

Add Fibreq to your Cargo.toml:

[dependencies]
fibreq = "0.1.0"

🚀 Quick Start

fn request() -> Result<(), fibreq::error::Error> {
    let client = fibreq::ClientBuilder::new().build();
    let response = client.get("https://google.ru").unwrap().send().unwrap();

    println!("Status: {}", response.status());
    if let Ok(text) = response.text() {
        println!("Body: {}", text);
    }
    Ok(())
}

Dependencies

~14–27MB
~417K SLoC