12 releases

0.6.1 Feb 19, 2024
0.6.0 Apr 27, 2023
0.5.2 Oct 24, 2022
0.5.0 Aug 8, 2022
0.1.0 Sep 7, 2020

#718 in Encoding

Download history 5069/week @ 2023-12-23 7233/week @ 2023-12-30 8623/week @ 2024-01-06 8836/week @ 2024-01-13 8473/week @ 2024-01-20 8850/week @ 2024-01-27 10692/week @ 2024-02-03 10757/week @ 2024-02-10 12118/week @ 2024-02-17 9995/week @ 2024-02-24 10775/week @ 2024-03-02 10561/week @ 2024-03-09 9963/week @ 2024-03-16 8620/week @ 2024-03-23 9462/week @ 2024-03-30 7684/week @ 2024-04-06

37,528 downloads per month
Used in 4 crates

MIT/Apache

30KB
490 lines

Parses and serializes the JSON dependency tree embedded in executables by the cargo auditable.

This crate defines the data structures that a serialized to/from JSON and implements the serialization/deserialization routines via serde. It also provides optional conversions from cargo metadata and to Cargo.lock formats.

The VersionInfo struct is where all the magic happens, see the docs on it for more info.

Basic usage

Note: this is a low-level crate that only implements JSON parsing. It rarely should be used directly. You probably want the higher-level auditable-info crate instead.

The following snippet demonstrates full extraction pipeline, including platform-specific executable handling via auditable-extract and decompression using the safe-Rust miniz_oxide:

use std::io::{Read, BufReader};
use std::{error::Error, fs::File, str::FromStr};

fn main() -> Result<(), Box<dyn Error>> {
    // Read the input
    let f = File::open("target/release/hello-world")?;
    let mut f = BufReader::new(f);
    let mut input_binary = Vec::new();
    f.read_to_end(&mut input_binary)?;
    // Extract the compressed audit data
    let compressed_audit_data = auditable_extract::raw_auditable_data(&input_binary)?;
    // Decompress it with your Zlib implementation of choice. We recommend miniz_oxide
    use miniz_oxide::inflate::decompress_to_vec_zlib;
    let decompressed_data = decompress_to_vec_zlib(&compressed_audit_data)
        .map_err(|_| "Failed to decompress audit data")?;
    let decompressed_data = String::from_utf8(decompressed_data)?;
    println!("{}", decompressed_data);
    // Parse the audit data to Rust data structures
    let dependency_tree = auditable_serde::VersionInfo::from_str(&decompressed_data);
    Ok(())
}

Dependencies

~0.7–1.9MB
~44K SLoC