#download #checksum #md5 #file

file-downloader

A Rust library to download and verify files, including MD5 checksum verification

1 unstable release

0.1.0 Dec 21, 2024

#55 in #md5

Download history 111/week @ 2024-12-19 4/week @ 2024-12-26

115 downloads per month
Used in file-downloader-derive

MIT license

40KB
605 lines

File Downloader

file_downloader is a Rust library designed to help you efficiently download and verify possibly md5 checksummed files. It offers functionality to:

  • Download files from a specified URL.
  • Verify downloaded files against provided MD5 checksums.
  • Store files locally and skip downloads if a verified local copy is available.

Features

  • Checksum Verification: Ensures the integrity of downloaded files by verifying their MD5 checksums.
  • Local Caching: Skips re-downloading files if a checksum-matching local copy is found.
  • Clean Abstraction: The FileDownloader trait provides a simple interface for downloading files, so you only need to implement the download method to leverage all of this crate’s functionality.

Example

use file_downloader::{FileDownloader, PbfDownloadError};
use std::path::PathBuf;
use async_trait::async_trait;

struct PlanetDownloader;

#[async_trait]
impl FileDownloader for PlanetDownloader {

    fn download_link(&self) -> &str {
        "https://planet.openstreetmap.org/pbf/planet-latest.osm.pbf"
    }
}

#[tokio::main]
async fn main() -> Result<(), PbfDownloadError> {
    let downloader = PlanetDownloader;
    let local_path = downloader.find_file_locally_or_download_into("./pbf_cache").await?;
    println!("file available at: {:?}", local_path);
    Ok(())
}

Testing

This crate includes a comprehensive test suite that covers:

  • MD5 checksum computation and verification
  • Filename manipulation functions
  • HTTP download handling, including mocking of HTTP responses
  • Integration tests for end-to-end downloading and verification

You can run tests with:

cargo test

License

This project is licensed under the MIT License. See the LICENSE file for details.

Dependencies

~12–24MB
~326K SLoC