2 releases

0.1.1 Sep 18, 2021
0.1.0 Sep 18, 2021

#844 in HTTP server

Download history 1770/week @ 2024-12-26 1843/week @ 2025-01-02 2412/week @ 2025-01-09 3059/week @ 2025-01-16 2284/week @ 2025-01-23 1886/week @ 2025-01-30 1601/week @ 2025-02-06 1184/week @ 2025-02-13 1168/week @ 2025-02-20 1431/week @ 2025-02-27 2073/week @ 2025-03-06 1969/week @ 2025-03-13 1757/week @ 2025-03-20 2336/week @ 2025-03-27 2279/week @ 2025-04-03 3247/week @ 2025-04-10

10,077 downloads per month

MIT license

21KB
364 lines

Mousse

An SSE encoder/decoder

Usage

Decode

use futures::stream::StreamExt;
use mousse::Parser;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let url = match std::env::args().nth(1) {
        Some(url) => url,
        None => {
            eprintln!("expected uri argument\ncargo run -- <uri>");
            std::process::exit(1);
        }
    };
    let mut stream = reqwest::get(&url)
        .await?
        .bytes_stream();
    while let Some(chunk) = stream.next().await {
        let chunk = chunk?;
        let string = String::from_utf8_lossy(&chunk);
        let mut parser = Parser::new(&string);
        println!("{:?}", parser.next_event());
    }
    Ok(())
}

Output

If you connect this to an sse server, you might see something like this.

cargo run --example reqwest -- http://localhost:8080/sse
Some(ServerSentEvent { comment: None, event: None, id: None, data: Some("next tick in 5"), retry: None })
Some(ServerSentEvent { comment: Some(""), event: None, id: None, data: None, retry: None })
Some(ServerSentEvent { comment: None, event: None, id: None, data: Some("next tick in 4"), retry: None })
Some(ServerSentEvent { comment: Some(""), event: None, id: None, data: None, retry: None })
Some(ServerSentEvent { comment: None, event: None, id: None, data: Some("next tick in 2"), retry: None })
Some(ServerSentEvent { comment: None, event: None, id: None, data: Some("next tick in 1"), retry: None })

Encode

use mousse::ServerSentEvent;

fn main() {
    for i in 0..10 {
        println!(
            "{}",
            ServerSentEvent::builder()
                .data(&format!("{}: Hi I am a data field", i))
                .id(&i.to_string())
                .build()
        )
    }
}

Output

cargo run --example encode
id:0
data:0: Hi I am a data field


id:1
data:1: Hi I am a data field


id:2
data:2: Hi I am a data field


id:3
data:3: Hi I am a data field


id:4
data:4: Hi I am a data field


id:5
data:5: Hi I am a data field


id:6
data:6: Hi I am a data field


id:7
data:7: Hi I am a data field


id:8
data:8: Hi I am a data field


id:9
data:9: Hi I am a data field


Dependencies

~90KB