6 releases (breaking)

0.6.0 Mar 29, 2024
0.5.0 Oct 4, 2023
0.4.0 Feb 21, 2022
0.3.0 Jan 11, 2022
0.1.0 Jun 28, 2020

#18 in HTTP client

Download history 18526/week @ 2024-10-30 17822/week @ 2024-11-06 17773/week @ 2024-11-13 19150/week @ 2024-11-20 18971/week @ 2024-11-27 20016/week @ 2024-12-04 19686/week @ 2024-12-11 16543/week @ 2024-12-18 9923/week @ 2024-12-25 15138/week @ 2025-01-01 24368/week @ 2025-01-08 23767/week @ 2025-01-15 25209/week @ 2025-01-22 28108/week @ 2025-01-29 26224/week @ 2025-02-05 19757/week @ 2025-02-12

103,554 downloads per month
Used in 189 crates (53 directly)

MIT/Apache

21KB
403 lines

reqwest-eventsource

Provides a simple wrapper for reqwest to provide an Event Source implementation. You can learn more about Server Sent Events (SSE) take a look at the MDN docs This crate uses eventsource_stream to wrap the underlying Bytes stream, and retries failed requests.

Example

let mut es = EventSource::get("http://localhost:8000/events");
while let Some(event) = es.next().await {
    match event {
        Ok(Event::Open) => println!("Connection Open!"),
        Ok(Event::Message(message)) => println!("Message: {:#?}", message),
        Err(err) => {
            println!("Error: {}", err);
            es.close();
        }
    }
}

License: MIT OR Apache-2.0


lib.rs:

Provides a simple wrapper for reqwest to provide an Event Source implementation. You can learn more about Server Sent Events (SSE) take a look at the MDN docs This crate uses eventsource_stream to wrap the underlying Bytes stream, and retries failed requests.

Example

let mut es = EventSource::get("http://localhost:8000/events");
while let Some(event) = es.next().await {
    match event {
        Ok(Event::Open) => println!("Connection Open!"),
        Ok(Event::Message(message)) => println!("Message: {:#?}", message),
        Err(err) => {
            println!("Error: {}", err);
            es.close();
        }
    }
}

Dependencies

~5–16MB
~210K SLoC