8 releases (4 breaking)

0.5.2 Jul 9, 2024
0.5.1 Jul 9, 2024
0.4.2 Jul 9, 2024
0.3.0 Jul 1, 2019
0.1.0 Jan 4, 2019

#55 in Video

Download history 341/week @ 2024-09-18 506/week @ 2024-09-25 385/week @ 2024-10-02 375/week @ 2024-10-09 414/week @ 2024-10-16 360/week @ 2024-10-23 355/week @ 2024-10-30 389/week @ 2024-11-06 443/week @ 2024-11-13 654/week @ 2024-11-20 494/week @ 2024-11-27 852/week @ 2024-12-04 550/week @ 2024-12-11 453/week @ 2024-12-18 319/week @ 2024-12-25 427/week @ 2025-01-01

1,792 downloads per month
Used in 3 crates (2 directly)

ISC license

28KB
640 lines

Stream Lib

This library makes it possible to download various types of video streams. Currently it supports HLS and chunked http streams.

Example

use futures_util::StreamExt as _;
use reqwest::Client;
use stream_lib::Event;
use tokio::io::AsyncWriteExt;

/// Write buffer
pub const WRITE_SIZE: usize = 131_072;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    tracing_subscriber::fmt::init();
    let args = std::env::args().collect::<Vec<_>>();
    let url = args.get(1).expect("Pass a url as the first argument");

    let http = Client::new();
    let req = http.get(url).build()?;
    let mut dl = stream_lib::download_hls(http, req, None);

    let mut file = tokio::io::BufWriter::with_capacity(
        WRITE_SIZE,
        tokio::fs::File::create("./example.mp4").await?,
    );

    while let Some(event) = dl.next().await {
        match event {
            Event::Bytes { bytes } => {
                file.write_all(&bytes).await?;
            }
            Event::End => break,
            Event::Error { error } => {
                eprintln!("Encounted error: {}", error);
                break;
            }
        }
    }
    Ok(())
}

Dependencies

~8–20MB
~260K SLoC